diff --git a/.eslintignore b/.eslintignore new file mode 100644 index 0000000000..50ac3d6a64 --- /dev/null +++ b/.eslintignore @@ -0,0 +1,7 @@ +bazel-* +coverage/ +dist/ +docs/ +lib/ +node_modules/ +public/ \ No newline at end of file diff --git a/.eslintrc.json b/.eslintrc.json new file mode 100644 index 0000000000..db5da1f057 --- /dev/null +++ b/.eslintrc.json @@ -0,0 +1,34 @@ +{ + "extends": ["eslint:recommended", "plugin:prettier/recommended"], + "parserOptions": { + "ecmaVersion": 12, + "sourceType": "module" + }, + "plugins": ["jest"], + "rules": { + "no-var": 2, + "prefer-arrow-callback": 2 + }, + "overrides": [ + { + "files": ["*.ts", "*.tsx"], + "parser": "@typescript-eslint/parser", + "plugins": ["@typescript-eslint"], + "extends": ["plugin:@typescript-eslint/recommended"], + "rules": { + "@typescript-eslint/ban-ts-comment": 0, + "@typescript-eslint/ban-types": 1, + "@typescript-eslint/no-empty-function": 1, + "@typescript-eslint/no-var-requires": 0, + "@typescript-eslint/member-ordering": 1 + } + } + ], + "env": { + "browser": false, + "node": true, + "es6": true, + "jest/globals": true + }, + "globals": { "google": "readonly" } +} diff --git a/e2e/client.test.ts b/e2e/client.test.ts index 5eeaadd80e..b1e39a38c0 100644 --- a/e2e/client.test.ts +++ b/e2e/client.test.ts @@ -14,7 +14,12 @@ * limitations under the License. */ -import { Client, defaultAxiosInstance, defaultHttpsAgent, type ElevationResponse } from "../src"; +import { + Client, + defaultAxiosInstance, + defaultHttpsAgent, + type ElevationResponse, +} from "../src"; import { AxiosError } from "axios"; test("client should work with defaults", async () => { diff --git a/e2e/compression.test.ts b/e2e/compression.test.ts index 7bdda1366b..09ea88a938 100644 --- a/e2e/compression.test.ts +++ b/e2e/compression.test.ts @@ -22,7 +22,7 @@ test("server responds with compressed content", async () => { origin: "Seattle, WA", destination: "San Francisco, CA", waypoints: [{ lat: 40, lng: -120 }], - key: process.env.GOOGLE_MAPS_API_KEY + key: process.env.GOOGLE_MAPS_API_KEY, }; // Use of directions here is entirely arbitrary and any API that supports @@ -36,9 +36,10 @@ test("server responds with compressed content", async () => { // that the server responds with a compressed response must be done via the // raw headers. - const {rawHeaders} = r.request.res; - const contentEncodingIndex = rawHeaders - .findIndex(i => i.toLowerCase() === "content-encoding"); + const { rawHeaders } = r.request.res; + const contentEncodingIndex = rawHeaders.findIndex( + (i) => i.toLowerCase() === "content-encoding" + ); expect(contentEncodingIndex).not.toBe(-1); expect(rawHeaders[contentEncodingIndex + 1]).toBe("gzip"); diff --git a/e2e/elevation.test.ts b/e2e/elevation.test.ts index e154d1f395..5443c6180d 100644 --- a/e2e/elevation.test.ts +++ b/e2e/elevation.test.ts @@ -14,7 +14,6 @@ * limitations under the License. */ -import axios from "axios"; import { elevation } from "../src/elevation"; test("elevation should return correct result", async () => { @@ -22,7 +21,7 @@ test("elevation should return correct result", async () => { const params = { locations: [location, location], - key: process.env.GOOGLE_MAPS_API_KEY + key: process.env.GOOGLE_MAPS_API_KEY, }; const r = await elevation({ params: params }); @@ -33,13 +32,13 @@ test("elevation should return correct result", async () => { test("elevation should return correct result with path params", async () => { const path = [ { lat: 35, lng: -110 }, - { lat: 45, lng: -110 } + { lat: 45, lng: -110 }, ]; const params = { path: path, samples: 10, - key: process.env.GOOGLE_MAPS_API_KEY + key: process.env.GOOGLE_MAPS_API_KEY, }; const r = await elevation({ params: params }); diff --git a/e2e/geocode/geocode.test.ts b/e2e/geocode/geocode.test.ts index 76249adfbd..95e134f56b 100644 --- a/e2e/geocode/geocode.test.ts +++ b/e2e/geocode/geocode.test.ts @@ -14,7 +14,7 @@ * limitations under the License. */ -import { geocode, GeocodeRequest } from "../../src/geocode/geocode"; +import { geocode } from "../../src/geocode/geocode"; test("geocode should call axios correctly", async () => { const params = { @@ -22,9 +22,9 @@ test("geocode should call axios correctly", async () => { components: { country: "us" }, bounds: { northeast: { lat: 50, lng: -110 }, - southwest: { lat: 35, lng: -130 } + southwest: { lat: 35, lng: -130 }, }, - key: process.env.GOOGLE_MAPS_API_KEY + key: process.env.GOOGLE_MAPS_API_KEY, }; const r = await geocode({ params: params }); diff --git a/e2e/geocode/reversegeocode.test.ts b/e2e/geocode/reversegeocode.test.ts index 381cb66fcc..4e452d4f08 100644 --- a/e2e/geocode/reversegeocode.test.ts +++ b/e2e/geocode/reversegeocode.test.ts @@ -20,9 +20,9 @@ test("reverseGeocode should return correct response", async () => { const params = { latlng: { lat: 60.168997, - lng: 24.9433353 + lng: 24.9433353, }, - key: process.env.GOOGLE_MAPS_API_KEY + key: process.env.GOOGLE_MAPS_API_KEY, }; const r = await reverseGeocode({ params: params }); expect(r.data.results.length).toBeTruthy(); @@ -31,7 +31,7 @@ test("reverseGeocode should return correct response", async () => { test("reverseGeocode should return correct response using place_id", async () => { const params = { place_id: "ChIJKxDbe_lYwokRVf__s8CPn-o", - key: process.env.GOOGLE_MAPS_API_KEY + key: process.env.GOOGLE_MAPS_API_KEY, }; const r = await reverseGeocode({ params: params }); expect(r.data.results.length).toBeTruthy(); diff --git a/e2e/roads/nearestroads.test.ts b/e2e/roads/nearestroads.test.ts index f52f230a1d..a7f9007d4d 100644 --- a/e2e/roads/nearestroads.test.ts +++ b/e2e/roads/nearestroads.test.ts @@ -20,7 +20,7 @@ import { LatLng } from "../../src/common"; test("nearestRoads should return correct response", async () => { const params = { points: [[60.17088, 24.942795] as LatLng], - key: process.env.GOOGLE_MAPS_API_KEY + key: process.env.GOOGLE_MAPS_API_KEY, }; const r = await nearestRoads({ params: params }); diff --git a/e2e/roads/snaptoroads.test.ts b/e2e/roads/snaptoroads.test.ts index 01eb3f6046..5619fbd22e 100644 --- a/e2e/roads/snaptoroads.test.ts +++ b/e2e/roads/snaptoroads.test.ts @@ -22,10 +22,10 @@ test("snapToRoads should have corect result", async () => { path: [ [60.17088, 24.942795] as LatLng, [60.170879, 24.942796] as LatLng, - [60.170877, 24.942796] as LatLng + [60.170877, 24.942796] as LatLng, ], interpolate: false, - key: process.env.GOOGLE_MAPS_API_KEY + key: process.env.GOOGLE_MAPS_API_KEY, }; const r = await snapToRoads({ params: params }); diff --git a/e2e/timezone.test.ts b/e2e/timezone.test.ts index 19c03b0ee9..0255d47ab2 100644 --- a/e2e/timezone.test.ts +++ b/e2e/timezone.test.ts @@ -23,7 +23,7 @@ test("elevation should get an ok response", async () => { location: "30, 50", timestamp: new Date(), language: Language.en, - key: process.env.GOOGLE_MAPS_API_KEY + key: process.env.GOOGLE_MAPS_API_KEY, }; const r = await timezone({ params: params }); diff --git a/jest.config.js b/jest.config.js index 2b59cf2918..4df50da0ce 100644 --- a/jest.config.js +++ b/jest.config.js @@ -19,7 +19,9 @@ module.exports = { preset: "ts-jest/presets/js-with-ts", testEnvironment: "node", // some dependencies are esm and need to be compiled to work in jest - transformIgnorePatterns: ['/node_modules/(?!(axios|retry-axios|query-string|decode-uri-component|split-on-first|filter-obj)/)'], + transformIgnorePatterns: [ + "/node_modules/(?!(axios|retry-axios|query-string|decode-uri-component|split-on-first|filter-obj)/)", + ], collectCoverage: true, - collectCoverageFrom: ["src/**/([a-zA-Z_]*).{js,ts}", "!**/*.test.{js,ts}"] + collectCoverageFrom: ["src/**/([a-zA-Z_]*).{js,ts}", "!**/*.test.{js,ts}"], }; diff --git a/package-lock.json b/package-lock.json index 68291441d0..42c56f26bf 100644 --- a/package-lock.json +++ b/package-lock.json @@ -4,6 +4,12 @@ "lockfileVersion": 1, "requires": true, "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==", + "dev": true + }, "@ampproject/remapping": { "version": "2.2.1", "resolved": "https://registry.npmjs.org/@ampproject/remapping/-/remapping-2.2.1.tgz", @@ -471,6 +477,76 @@ "integrity": "sha512-0hYQ8SB4Db5zvZB4axdMHGwEaQjkZzFjQiN9LVYvIFB2nSUHW9tYpxWriPrWDASIxiaXax83REcLxuSdnGPZtw==", "dev": true }, + "@eslint-community/eslint-utils": { + "version": "4.4.0", + "resolved": "https://registry.npmjs.org/@eslint-community/eslint-utils/-/eslint-utils-4.4.0.tgz", + "integrity": "sha512-1/sA4dwrzBAyeUoQ6oxahHKmrZvsnLCg4RfxW3ZFGGmQkSNQPFNLV9CUEFQP1x9EYXHTo5p6xdhZM1Ne9p/AfA==", + "dev": true, + "requires": { + "eslint-visitor-keys": "^3.3.0" + } + }, + "@eslint-community/regexpp": { + "version": "4.9.1", + "resolved": "https://registry.npmjs.org/@eslint-community/regexpp/-/regexpp-4.9.1.tgz", + "integrity": "sha512-Y27x+MBLjXa+0JWDhykM3+JE+il3kHKAEqabfEWq3SDhZjLYb6/BHL/JKFnH3fe207JaXkyDo685Oc2Glt6ifA==", + "dev": true + }, + "@eslint/eslintrc": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-2.1.2.tgz", + "integrity": "sha512-+wvgpDsrB1YqAMdEUCcnTlpfVBH7Vqn6A/NT3D8WVXFIaKMlErPIZT3oCIAVCOtarRpMtelZLqJeU3t7WY6X6g==", + "dev": true, + "requires": { + "ajv": "^6.12.4", + "debug": "^4.3.2", + "espree": "^9.6.0", + "globals": "^13.19.0", + "ignore": "^5.2.0", + "import-fresh": "^3.2.1", + "js-yaml": "^4.1.0", + "minimatch": "^3.1.2", + "strip-json-comments": "^3.1.1" + }, + "dependencies": { + "argparse": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz", + "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==", + "dev": true + }, + "globals": { + "version": "13.23.0", + "resolved": "https://registry.npmjs.org/globals/-/globals-13.23.0.tgz", + "integrity": "sha512-XAmF0RjlrjY23MA51q3HltdlGxUpXPvg0GioKiD9X6HD28iMjo2dKC8Vqwm7lne4GNr78+RHTfliktR6ZH09wA==", + "dev": true, + "requires": { + "type-fest": "^0.20.2" + } + }, + "js-yaml": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz", + "integrity": "sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==", + "dev": true, + "requires": { + "argparse": "^2.0.1" + } + }, + "type-fest": { + "version": "0.20.2", + "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.20.2.tgz", + "integrity": "sha512-Ne+eE4r0/iWnpAxD852z3A+N0Bt5RN//NjJwRd2VFHEmrywxf5vsZlh4R6lixl6B+wz/8d+maTSAkN1FIkI3LQ==", + "dev": true + } + } + }, + "@eslint/js": { + "version": "8.51.0", + "resolved": "https://registry.npmjs.org/@eslint/js/-/js-8.51.0.tgz", + "integrity": "sha512-HxjQ8Qn+4SI3/AFv6sOrDB+g6PpUTDwSJiQqOrnneEk8L71161srI9gjzzZvYVbzHiVg/BvcH95+cK/zfIt4pg==", + "dev": true + }, "@googlemaps/url-signature": { "version": "1.0.29", "resolved": "https://registry.npmjs.org/@googlemaps/url-signature/-/url-signature-1.0.29.tgz", @@ -479,6 +555,29 @@ "crypto-js": "^4.1.1" } }, + "@humanwhocodes/config-array": { + "version": "0.11.11", + "resolved": "https://registry.npmjs.org/@humanwhocodes/config-array/-/config-array-0.11.11.tgz", + "integrity": "sha512-N2brEuAadi0CcdeMXUkhbZB84eskAc8MEX1By6qEchoVywSgXPIjou4rYsl0V3Hj0ZnuGycGCjdNgockbzeWNA==", + "dev": true, + "requires": { + "@humanwhocodes/object-schema": "^1.2.1", + "debug": "^4.1.1", + "minimatch": "^3.0.5" + } + }, + "@humanwhocodes/module-importer": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/@humanwhocodes/module-importer/-/module-importer-1.0.1.tgz", + "integrity": "sha512-bxveV4V8v5Yb4ncFTT3rPSgZBOpCkjfK0y4oVVVJwIuDVBRMDXrPyXRL988i5ap9m9bnyEEjWfm5WkBmtffLfA==", + "dev": true + }, + "@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==", + "dev": true + }, "@istanbuljs/load-nyc-config": { "version": "1.1.0", "resolved": "https://registry.npmjs.org/@istanbuljs/load-nyc-config/-/load-nyc-config-1.1.0.tgz", @@ -757,6 +856,54 @@ "@jridgewell/sourcemap-codec": "^1.4.14" } }, + "@nodelib/fs.scandir": { + "version": "2.1.5", + "resolved": "https://registry.npmjs.org/@nodelib/fs.scandir/-/fs.scandir-2.1.5.tgz", + "integrity": "sha512-vq24Bq3ym5HEQm2NKCr3yXDwjc7vTsEThRDnkp2DK9p1uqLR+DHurm/NOTo0KG7HYHU7eppKZj3MyqYuMBf62g==", + "dev": true, + "requires": { + "@nodelib/fs.stat": "2.0.5", + "run-parallel": "^1.1.9" + } + }, + "@nodelib/fs.stat": { + "version": "2.0.5", + "resolved": "https://registry.npmjs.org/@nodelib/fs.stat/-/fs.stat-2.0.5.tgz", + "integrity": "sha512-RkhPPp2zrqDAQA/2jNhnztcPAlv64XdhIp7a7454A5ovI7Bukxgt7MX7udwAu3zg1DcpPU0rz3VV1SeaqvY4+A==", + "dev": true + }, + "@nodelib/fs.walk": { + "version": "1.2.8", + "resolved": "https://registry.npmjs.org/@nodelib/fs.walk/-/fs.walk-1.2.8.tgz", + "integrity": "sha512-oGB+UxlgWcgQkgwo8GcEGwemoTFt3FIO9ababBmaGwXIoBKZ+GTy0pP185beGg7Llih/NSHSV2XAs1lnznocSg==", + "dev": true, + "requires": { + "@nodelib/fs.scandir": "2.1.5", + "fastq": "^1.6.0" + } + }, + "@pkgr/utils": { + "version": "2.4.2", + "resolved": "https://registry.npmjs.org/@pkgr/utils/-/utils-2.4.2.tgz", + "integrity": "sha512-POgTXhjrTfbTV63DiFXav4lBHiICLKKwDeaKn9Nphwj7WH6m0hMMCaJkMyRWjgtPFyRKRVoMXXjczsTQRDEhYw==", + "dev": true, + "requires": { + "cross-spawn": "^7.0.3", + "fast-glob": "^3.3.0", + "is-glob": "^4.0.3", + "open": "^9.1.0", + "picocolors": "^1.0.0", + "tslib": "^2.6.0" + }, + "dependencies": { + "tslib": { + "version": "2.6.2", + "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.6.2.tgz", + "integrity": "sha512-AEYxH93jGFPn/a2iVAwW87VuUIkR1FVUKB77NwMF7nBTDkDrrT/Hpt/IrCJ0QXhW27jTBDcf5ZY7w6RiqTMw2Q==", + "dev": true + } + } + }, "@sinclair/typebox": { "version": "0.27.8", "resolved": "https://registry.npmjs.org/@sinclair/typebox/-/typebox-0.27.8.tgz", @@ -865,6 +1012,12 @@ "pretty-format": "^29.0.0" } }, + "@types/json-schema": { + "version": "7.0.13", + "resolved": "https://registry.npmjs.org/@types/json-schema/-/json-schema-7.0.13.tgz", + "integrity": "sha512-RbSSoHliUbnXj3ny0CNFOoxrIDV6SUGyStHsvDqosw6CkdPV8TtWGlfecuK4ToyMEAql6pzNxgCFKanovUzlgQ==", + "dev": true + }, "@types/node": { "version": "20.8.4", "resolved": "https://registry.npmjs.org/@types/node/-/node-20.8.4.tgz", @@ -874,6 +1027,12 @@ "undici-types": "~5.25.1" } }, + "@types/semver": { + "version": "7.5.3", + "resolved": "https://registry.npmjs.org/@types/semver/-/semver-7.5.3.tgz", + "integrity": "sha512-OxepLK9EuNEIPxWNME+C6WwbRAOOI2o2BaQEGzz5Lu2e4Z5eDnEo+/aVEDMIXywoJitJ7xWd641wrGLZdtwRyw==", + "dev": true + }, "@types/stack-utils": { "version": "2.0.1", "resolved": "https://registry.npmjs.org/@types/stack-utils/-/stack-utils-2.0.1.tgz", @@ -895,6 +1054,196 @@ "integrity": "sha512-axdPBuLuEJt0c4yI5OZssC19K2Mq1uKdrfZBzuxLvaztgqUtFYZUNw7lETExPYJR9jdEoIg4mb7RQKRQzOkeGQ==", "dev": true }, + "@typescript-eslint/eslint-plugin": { + "version": "6.7.5", + "resolved": "https://registry.npmjs.org/@typescript-eslint/eslint-plugin/-/eslint-plugin-6.7.5.tgz", + "integrity": "sha512-JhtAwTRhOUcP96D0Y6KYnwig/MRQbOoLGXTON2+LlyB/N35SP9j1boai2zzwXb7ypKELXMx3DVk9UTaEq1vHEw==", + "dev": true, + "requires": { + "@eslint-community/regexpp": "^4.5.1", + "@typescript-eslint/scope-manager": "6.7.5", + "@typescript-eslint/type-utils": "6.7.5", + "@typescript-eslint/utils": "6.7.5", + "@typescript-eslint/visitor-keys": "6.7.5", + "debug": "^4.3.4", + "graphemer": "^1.4.0", + "ignore": "^5.2.4", + "natural-compare": "^1.4.0", + "semver": "^7.5.4", + "ts-api-utils": "^1.0.1" + }, + "dependencies": { + "lru-cache": { + "version": "6.0.0", + "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", + "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", + "dev": true, + "requires": { + "yallist": "^4.0.0" + } + }, + "semver": { + "version": "7.5.4", + "resolved": "https://registry.npmjs.org/semver/-/semver-7.5.4.tgz", + "integrity": "sha512-1bCSESV6Pv+i21Hvpxp3Dx+pSD8lIPt8uVjRrxAUt/nbswYc+tK6Y2btiULjd4+fnq15PX+nqQDC7Oft7WkwcA==", + "dev": true, + "requires": { + "lru-cache": "^6.0.0" + } + }, + "yallist": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", + "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", + "dev": true + } + } + }, + "@typescript-eslint/parser": { + "version": "6.7.5", + "resolved": "https://registry.npmjs.org/@typescript-eslint/parser/-/parser-6.7.5.tgz", + "integrity": "sha512-bIZVSGx2UME/lmhLcjdVc7ePBwn7CLqKarUBL4me1C5feOd663liTGjMBGVcGr+BhnSLeP4SgwdvNnnkbIdkCw==", + "dev": true, + "requires": { + "@typescript-eslint/scope-manager": "6.7.5", + "@typescript-eslint/types": "6.7.5", + "@typescript-eslint/typescript-estree": "6.7.5", + "@typescript-eslint/visitor-keys": "6.7.5", + "debug": "^4.3.4" + } + }, + "@typescript-eslint/scope-manager": { + "version": "6.7.5", + "resolved": "https://registry.npmjs.org/@typescript-eslint/scope-manager/-/scope-manager-6.7.5.tgz", + "integrity": "sha512-GAlk3eQIwWOJeb9F7MKQ6Jbah/vx1zETSDw8likab/eFcqkjSD7BI75SDAeC5N2L0MmConMoPvTsmkrg71+B1A==", + "dev": true, + "requires": { + "@typescript-eslint/types": "6.7.5", + "@typescript-eslint/visitor-keys": "6.7.5" + } + }, + "@typescript-eslint/type-utils": { + "version": "6.7.5", + "resolved": "https://registry.npmjs.org/@typescript-eslint/type-utils/-/type-utils-6.7.5.tgz", + "integrity": "sha512-Gs0qos5wqxnQrvpYv+pf3XfcRXW6jiAn9zE/K+DlmYf6FcpxeNYN0AIETaPR7rHO4K2UY+D0CIbDP9Ut0U4m1g==", + "dev": true, + "requires": { + "@typescript-eslint/typescript-estree": "6.7.5", + "@typescript-eslint/utils": "6.7.5", + "debug": "^4.3.4", + "ts-api-utils": "^1.0.1" + } + }, + "@typescript-eslint/types": { + "version": "6.7.5", + "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-6.7.5.tgz", + "integrity": "sha512-WboQBlOXtdj1tDFPyIthpKrUb+kZf2VroLZhxKa/VlwLlLyqv/PwUNgL30BlTVZV1Wu4Asu2mMYPqarSO4L5ZQ==", + "dev": true + }, + "@typescript-eslint/typescript-estree": { + "version": "6.7.5", + "resolved": "https://registry.npmjs.org/@typescript-eslint/typescript-estree/-/typescript-estree-6.7.5.tgz", + "integrity": "sha512-NhJiJ4KdtwBIxrKl0BqG1Ur+uw7FiOnOThcYx9DpOGJ/Abc9z2xNzLeirCG02Ig3vkvrc2qFLmYSSsaITbKjlg==", + "dev": true, + "requires": { + "@typescript-eslint/types": "6.7.5", + "@typescript-eslint/visitor-keys": "6.7.5", + "debug": "^4.3.4", + "globby": "^11.1.0", + "is-glob": "^4.0.3", + "semver": "^7.5.4", + "ts-api-utils": "^1.0.1" + }, + "dependencies": { + "lru-cache": { + "version": "6.0.0", + "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", + "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", + "dev": true, + "requires": { + "yallist": "^4.0.0" + } + }, + "semver": { + "version": "7.5.4", + "resolved": "https://registry.npmjs.org/semver/-/semver-7.5.4.tgz", + "integrity": "sha512-1bCSESV6Pv+i21Hvpxp3Dx+pSD8lIPt8uVjRrxAUt/nbswYc+tK6Y2btiULjd4+fnq15PX+nqQDC7Oft7WkwcA==", + "dev": true, + "requires": { + "lru-cache": "^6.0.0" + } + }, + "yallist": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", + "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", + "dev": true + } + } + }, + "@typescript-eslint/utils": { + "version": "6.7.5", + "resolved": "https://registry.npmjs.org/@typescript-eslint/utils/-/utils-6.7.5.tgz", + "integrity": "sha512-pfRRrH20thJbzPPlPc4j0UNGvH1PjPlhlCMq4Yx7EGjV7lvEeGX0U6MJYe8+SyFutWgSHsdbJ3BXzZccYggezA==", + "dev": true, + "requires": { + "@eslint-community/eslint-utils": "^4.4.0", + "@types/json-schema": "^7.0.12", + "@types/semver": "^7.5.0", + "@typescript-eslint/scope-manager": "6.7.5", + "@typescript-eslint/types": "6.7.5", + "@typescript-eslint/typescript-estree": "6.7.5", + "semver": "^7.5.4" + }, + "dependencies": { + "lru-cache": { + "version": "6.0.0", + "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", + "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", + "dev": true, + "requires": { + "yallist": "^4.0.0" + } + }, + "semver": { + "version": "7.5.4", + "resolved": "https://registry.npmjs.org/semver/-/semver-7.5.4.tgz", + "integrity": "sha512-1bCSESV6Pv+i21Hvpxp3Dx+pSD8lIPt8uVjRrxAUt/nbswYc+tK6Y2btiULjd4+fnq15PX+nqQDC7Oft7WkwcA==", + "dev": true, + "requires": { + "lru-cache": "^6.0.0" + } + }, + "yallist": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", + "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", + "dev": true + } + } + }, + "@typescript-eslint/visitor-keys": { + "version": "6.7.5", + "resolved": "https://registry.npmjs.org/@typescript-eslint/visitor-keys/-/visitor-keys-6.7.5.tgz", + "integrity": "sha512-3MaWdDZtLlsexZzDSdQWsFQ9l9nL8B80Z4fImSpyllFC/KLqWQRdEcB+gGGO+N3Q2uL40EsG66wZLsohPxNXvg==", + "dev": true, + "requires": { + "@typescript-eslint/types": "6.7.5", + "eslint-visitor-keys": "^3.4.1" + } + }, + "acorn": { + "version": "8.10.0", + "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.10.0.tgz", + "integrity": "sha512-F0SAmZ8iUtS//m8DmCTA0jlh6TDKkHQyK6xc6V4KDTyZKA9dnvX9/3sRTVQrWm79glUAZbnmmNcdYwUIHWVybw==", + "dev": true + }, + "acorn-jsx": { + "version": "5.3.2", + "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.3.2.tgz", + "integrity": "sha512-rq9s+JNhf0IChjtDXxllJ7g41oZk5SlXtp0LHwyA5cejwn7vKmKp4pPri6YEePv2PU65sAsegbXtIinmDFDXgQ==", + "dev": true + }, "agentkeepalive": { "version": "4.5.0", "resolved": "https://registry.npmjs.org/agentkeepalive/-/agentkeepalive-4.5.0.tgz", @@ -903,6 +1252,18 @@ "humanize-ms": "^1.2.1" } }, + "ajv": { + "version": "6.12.6", + "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz", + "integrity": "sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==", + "dev": true, + "requires": { + "fast-deep-equal": "^3.1.1", + "fast-json-stable-stringify": "^2.0.0", + "json-schema-traverse": "^0.4.1", + "uri-js": "^4.2.2" + } + }, "ansi-escapes": { "version": "4.3.2", "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-4.3.2.tgz", @@ -952,6 +1313,12 @@ "sprintf-js": "~1.0.2" } }, + "array-union": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/array-union/-/array-union-2.1.0.tgz", + "integrity": "sha512-HGyxoOTYUyCM6stUe6EJgnd4EoewAI7zMdfqO+kGjnlZmBDz/cR5pf8r/cR4Wq60sL/p0IkcjUEEPwS3GFrIyw==", + "dev": true + }, "asynckit": { "version": "0.4.0", "resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz", @@ -1058,6 +1425,21 @@ "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", "dev": true }, + "big-integer": { + "version": "1.6.51", + "resolved": "https://registry.npmjs.org/big-integer/-/big-integer-1.6.51.tgz", + "integrity": "sha512-GPEid2Y9QU1Exl1rpO9B2IPJGHPSupF5GnVIP0blYvNOMer2bTvSWs1jGOUg04hTmu67nmLsQ9TBo1puaotBHg==", + "dev": true + }, + "bplist-parser": { + "version": "0.2.0", + "resolved": "https://registry.npmjs.org/bplist-parser/-/bplist-parser-0.2.0.tgz", + "integrity": "sha512-z0M+byMThzQmD9NILRniCUXYsYpjwnlO8N5uCFaCqIOpqRsJCrQL9NK3JsD67CN5a08nF5oIL2bD6loTdHOuKw==", + "dev": true, + "requires": { + "big-integer": "^1.6.44" + } + }, "brace-expansion": { "version": "1.1.11", "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", @@ -1113,6 +1495,15 @@ "integrity": "sha512-E+XQCRwSbaaiChtv6k6Dwgc+bx+Bs6vuKJHHl5kox/BaKbhiXzqQOwK4cO22yElGp2OCmjwVhT3HmxgyPGnJfQ==", "dev": true }, + "bundle-name": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/bundle-name/-/bundle-name-3.0.0.tgz", + "integrity": "sha512-PKA4BeSvBpQKQ8iPOGCSiell+N8P+Tf1DlwqmYhpe2gAhKPHn8EYOxVT+ShuGmhg8lN8XiSlS80yiExKXrURlw==", + "dev": true, + "requires": { + "run-applescript": "^5.0.0" + } + }, "callsites": { "version": "3.1.0", "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", @@ -1276,72 +1667,501 @@ "integrity": "sha512-+LxW+KLWxu3HW3M2w2ympwtqPrqYRzU8fqi6Fhd18fBALe15blJPI/I4+UHveMVG6lJqB4JNd4UG0S5cnVHwIg==", "dev": true }, + "deep-is": { + "version": "0.1.4", + "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.4.tgz", + "integrity": "sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ==", + "dev": true + }, "deepmerge": { "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 }, + "default-browser": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/default-browser/-/default-browser-4.0.0.tgz", + "integrity": "sha512-wX5pXO1+BrhMkSbROFsyxUm0i/cJEScyNhA4PPxc41ICuv05ZZB/MX28s8aZx6xjmatvebIapF6hLEKEcpneUA==", + "dev": true, + "requires": { + "bundle-name": "^3.0.0", + "default-browser-id": "^3.0.0", + "execa": "^7.1.1", + "titleize": "^3.0.0" + }, + "dependencies": { + "execa": { + "version": "7.2.0", + "resolved": "https://registry.npmjs.org/execa/-/execa-7.2.0.tgz", + "integrity": "sha512-UduyVP7TLB5IcAQl+OzLyLcS/l32W/GLg+AhHJ+ow40FOk2U3SAllPwR44v4vmdFwIWqpdwxxpQbF1n5ta9seA==", + "dev": true, + "requires": { + "cross-spawn": "^7.0.3", + "get-stream": "^6.0.1", + "human-signals": "^4.3.0", + "is-stream": "^3.0.0", + "merge-stream": "^2.0.0", + "npm-run-path": "^5.1.0", + "onetime": "^6.0.0", + "signal-exit": "^3.0.7", + "strip-final-newline": "^3.0.0" + } + }, + "human-signals": { + "version": "4.3.1", + "resolved": "https://registry.npmjs.org/human-signals/-/human-signals-4.3.1.tgz", + "integrity": "sha512-nZXjEF2nbo7lIw3mgYjItAfgQXog3OjJogSbKa2CQIIvSGWcKgeJnQlNXip6NglNzYH45nSRiEVimMvYL8DDqQ==", + "dev": true + }, + "is-stream": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-3.0.0.tgz", + "integrity": "sha512-LnQR4bZ9IADDRSkvpqMGvt/tEJWclzklNgSw48V5EAaAeDd6qGvN8ei6k5p0tvxSR171VmGyHuTiAOfxAbr8kA==", + "dev": true + }, + "mimic-fn": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-4.0.0.tgz", + "integrity": "sha512-vqiC06CuhBTUdZH+RYl8sFrL096vA45Ok5ISO6sE/Mr1jRbGH4Csnhi8f3wKVl7x8mO4Au7Ir9D3Oyv1VYMFJw==", + "dev": true + }, + "npm-run-path": { + "version": "5.1.0", + "resolved": "https://registry.npmjs.org/npm-run-path/-/npm-run-path-5.1.0.tgz", + "integrity": "sha512-sJOdmRGrY2sjNTRMbSvluQqg+8X7ZK61yvzBEIDhz4f8z1TZFYABsqjjCBd/0PUNE9M6QDgHJXQkGUEm7Q+l9Q==", + "dev": true, + "requires": { + "path-key": "^4.0.0" + } + }, + "onetime": { + "version": "6.0.0", + "resolved": "https://registry.npmjs.org/onetime/-/onetime-6.0.0.tgz", + "integrity": "sha512-1FlR+gjXK7X+AsAHso35MnyN5KqGwJRi/31ft6x0M194ht7S+rWAvd7PHss9xSKMzE0asv1pyIHaJYq+BbacAQ==", + "dev": true, + "requires": { + "mimic-fn": "^4.0.0" + } + }, + "path-key": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/path-key/-/path-key-4.0.0.tgz", + "integrity": "sha512-haREypq7xkM7ErfgIyA0z+Bj4AGKlMSdlQE2jvJo6huWD1EdkKYV+G/T4nq0YEF2vgTT8kqMFKo1uHn950r4SQ==", + "dev": true + }, + "strip-final-newline": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/strip-final-newline/-/strip-final-newline-3.0.0.tgz", + "integrity": "sha512-dOESqjYr96iWYylGObzd39EuNTa5VJxyvVAEm5Jnh7KGo75V43Hk1odPQkNDyXNmUR6k+gEiDVXnjB8HJ3crXw==", + "dev": true + } + } + }, + "default-browser-id": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/default-browser-id/-/default-browser-id-3.0.0.tgz", + "integrity": "sha512-OZ1y3y0SqSICtE8DE4S8YOE9UZOJ8wO16fKWVP5J1Qz42kV9jcnMVFrEE/noXb/ss3Q4pZIH79kxofzyNNtUNA==", + "dev": true, + "requires": { + "bplist-parser": "^0.2.0", + "untildify": "^4.0.0" + } + }, + "define-lazy-prop": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/define-lazy-prop/-/define-lazy-prop-3.0.0.tgz", + "integrity": "sha512-N+MeXYoqr3pOgn8xfyRPREN7gHakLYjhsHhWGT3fWAiL4IkAt0iDw14QiiEm2bE30c5XX5q0FtAA3CK5f9/BUg==", + "dev": true + }, "delayed-stream": { "version": "1.0.0", "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz", "integrity": "sha512-ZySD7Nf91aLB0RxL4KGrKHBXl7Eds1DAmEdcoVawXnLD7SDhpNgtuII2aAkg7a7QS41jxPSZ17p4VdGnMHk3MQ==" }, - "detect-newline": { - "version": "3.1.0", - "resolved": "https://registry.npmjs.org/detect-newline/-/detect-newline-3.1.0.tgz", - "integrity": "sha512-TLz+x/vEXm/Y7P7wn1EJFNLxYpUD4TgMosxY6fAVJUnJMbupHBOncxyWUG9OpTaH9EBD7uFI5LfEgmMOc54DsA==", - "dev": true + "detect-newline": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/detect-newline/-/detect-newline-3.1.0.tgz", + "integrity": "sha512-TLz+x/vEXm/Y7P7wn1EJFNLxYpUD4TgMosxY6fAVJUnJMbupHBOncxyWUG9OpTaH9EBD7uFI5LfEgmMOc54DsA==", + "dev": true + }, + "diff-sequences": { + "version": "29.6.3", + "resolved": "https://registry.npmjs.org/diff-sequences/-/diff-sequences-29.6.3.tgz", + "integrity": "sha512-EjePK1srD3P08o2j4f0ExnylqRs5B9tJjcp9t1krH2qRi8CCdsYfwe9JgSLurFBWwq4uOlipzfk5fHNvwFKr8Q==", + "dev": true + }, + "dir-glob": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/dir-glob/-/dir-glob-3.0.1.tgz", + "integrity": "sha512-WkrWp9GR4KXfKGYzOLmTuGVi1UWFfws377n9cc55/tb6DuqyF6pcQ5AbiHEshaDpY9v6oaSr2XCDidGmMwdzIA==", + "dev": true, + "requires": { + "path-type": "^4.0.0" + } + }, + "doctrine": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-3.0.0.tgz", + "integrity": "sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==", + "dev": true, + "requires": { + "esutils": "^2.0.2" + } + }, + "electron-to-chromium": { + "version": "1.4.544", + "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.4.544.tgz", + "integrity": "sha512-54z7squS1FyFRSUqq/knOFSptjjogLZXbKcYk3B0qkE1KZzvqASwRZnY2KzZQJqIYLVD38XZeoiMRflYSwyO4w==", + "dev": true + }, + "emittery": { + "version": "0.13.1", + "resolved": "https://registry.npmjs.org/emittery/-/emittery-0.13.1.tgz", + "integrity": "sha512-DeWwawk6r5yR9jFgnDKYt4sLS0LmHJJi3ZOnb5/JdbYwj3nW+FxQnHIjhBKz8YLC7oRNPVM9NQ47I3CVx34eqQ==", + "dev": true + }, + "emoji-regex": { + "version": "8.0.0", + "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", + "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", + "dev": true + }, + "error-ex": { + "version": "1.3.2", + "resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.2.tgz", + "integrity": "sha512-7dFHNmqeFSEt2ZBsCriorKnn3Z2pj+fd9kmI6QoWw4//DL+icEBfc0U7qJCisqrTsKTjw4fNFy2pW9OqStD84g==", + "dev": true, + "requires": { + "is-arrayish": "^0.2.1" + } + }, + "escalade": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.1.1.tgz", + "integrity": "sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw==", + "dev": true + }, + "escape-string-regexp": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", + "integrity": "sha512-vbRorB5FUQWvla16U8R/qgaFIya2qGzwDrNmCZuYKrbdSUMG6I1ZCGQRefkRVhuOkIGVne7BQ35DSfo1qvJqFg==", + "dev": true + }, + "eslint": { + "version": "8.51.0", + "resolved": "https://registry.npmjs.org/eslint/-/eslint-8.51.0.tgz", + "integrity": "sha512-2WuxRZBrlwnXi+/vFSJyjMqrNjtJqiasMzehF0shoLaW7DzS3/9Yvrmq5JiT66+pNjiX4UBnLDiKHcWAr/OInA==", + "dev": true, + "requires": { + "@eslint-community/eslint-utils": "^4.2.0", + "@eslint-community/regexpp": "^4.6.1", + "@eslint/eslintrc": "^2.1.2", + "@eslint/js": "8.51.0", + "@humanwhocodes/config-array": "^0.11.11", + "@humanwhocodes/module-importer": "^1.0.1", + "@nodelib/fs.walk": "^1.2.8", + "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.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", + "file-entry-cache": "^6.0.1", + "find-up": "^5.0.0", + "glob-parent": "^6.0.2", + "globals": "^13.19.0", + "graphemer": "^1.4.0", + "ignore": "^5.2.0", + "imurmurhash": "^0.1.4", + "is-glob": "^4.0.0", + "is-path-inside": "^3.0.3", + "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.3", + "strip-ansi": "^6.0.1", + "text-table": "^0.2.0" + }, + "dependencies": { + "argparse": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz", + "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==", + "dev": true + }, + "escape-string-regexp": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", + "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==", + "dev": true + }, + "find-up": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/find-up/-/find-up-5.0.0.tgz", + "integrity": "sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng==", + "dev": true, + "requires": { + "locate-path": "^6.0.0", + "path-exists": "^4.0.0" + } + }, + "glob-parent": { + "version": "6.0.2", + "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-6.0.2.tgz", + "integrity": "sha512-XxwI8EOhVQgWp6iDL+3b0r86f4d6AX6zSU55HfB4ydCEuXLXc5FcYeOu+nnGftS4TEju/11rt4KJPTMgbfmv4A==", + "dev": true, + "requires": { + "is-glob": "^4.0.3" + } + }, + "globals": { + "version": "13.23.0", + "resolved": "https://registry.npmjs.org/globals/-/globals-13.23.0.tgz", + "integrity": "sha512-XAmF0RjlrjY23MA51q3HltdlGxUpXPvg0GioKiD9X6HD28iMjo2dKC8Vqwm7lne4GNr78+RHTfliktR6ZH09wA==", + "dev": true, + "requires": { + "type-fest": "^0.20.2" + } + }, + "js-yaml": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz", + "integrity": "sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==", + "dev": true, + "requires": { + "argparse": "^2.0.1" + } + }, + "locate-path": { + "version": "6.0.0", + "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-6.0.0.tgz", + "integrity": "sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw==", + "dev": true, + "requires": { + "p-locate": "^5.0.0" + } + }, + "p-limit": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz", + "integrity": "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==", + "dev": true, + "requires": { + "yocto-queue": "^0.1.0" + } + }, + "p-locate": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-5.0.0.tgz", + "integrity": "sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw==", + "dev": true, + "requires": { + "p-limit": "^3.0.2" + } + }, + "type-fest": { + "version": "0.20.2", + "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.20.2.tgz", + "integrity": "sha512-Ne+eE4r0/iWnpAxD852z3A+N0Bt5RN//NjJwRd2VFHEmrywxf5vsZlh4R6lixl6B+wz/8d+maTSAkN1FIkI3LQ==", + "dev": true + } + } + }, + "eslint-config-prettier": { + "version": "9.0.0", + "resolved": "https://registry.npmjs.org/eslint-config-prettier/-/eslint-config-prettier-9.0.0.tgz", + "integrity": "sha512-IcJsTkJae2S35pRsRAwoCE+925rJJStOdkKnLVgtE+tEpqU0EVVM7OqrwxqgptKdX29NUwC82I5pXsGFIgSevw==", + "dev": true + }, + "eslint-plugin-jest": { + "version": "27.4.2", + "resolved": "https://registry.npmjs.org/eslint-plugin-jest/-/eslint-plugin-jest-27.4.2.tgz", + "integrity": "sha512-3Nfvv3wbq2+PZlRTf2oaAWXWwbdBejFRBR2O8tAO67o+P8zno+QGbcDYaAXODlreXVg+9gvWhKKmG2rgfb8GEg==", + "dev": true, + "requires": { + "@typescript-eslint/utils": "^5.10.0" + }, + "dependencies": { + "@typescript-eslint/scope-manager": { + "version": "5.62.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/scope-manager/-/scope-manager-5.62.0.tgz", + "integrity": "sha512-VXuvVvZeQCQb5Zgf4HAxc04q5j+WrNAtNh9OwCsCgpKqESMTu3tF/jhZ3xG6T4NZwWl65Bg8KuS2uEvhSfLl0w==", + "dev": true, + "requires": { + "@typescript-eslint/types": "5.62.0", + "@typescript-eslint/visitor-keys": "5.62.0" + } + }, + "@typescript-eslint/types": { + "version": "5.62.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-5.62.0.tgz", + "integrity": "sha512-87NVngcbVXUahrRTqIK27gD2t5Cu1yuCXxbLcFtCzZGlfyVWWh8mLHkoxzjsB6DDNnvdL+fW8MiwPEJyGJQDgQ==", + "dev": true + }, + "@typescript-eslint/typescript-estree": { + "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==", + "dev": true, + "requires": { + "@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", + "semver": "^7.3.7", + "tsutils": "^3.21.0" + } + }, + "@typescript-eslint/utils": { + "version": "5.62.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/utils/-/utils-5.62.0.tgz", + "integrity": "sha512-n8oxjeb5aIbPFEtmQxQYOLI0i9n5ySBEY/ZEHHZqKQSFnxio1rv6dthascc9dLuwrL0RC5mPCxB7vnAVGAYWAQ==", + "dev": true, + "requires": { + "@eslint-community/eslint-utils": "^4.2.0", + "@types/json-schema": "^7.0.9", + "@types/semver": "^7.3.12", + "@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.62.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/visitor-keys/-/visitor-keys-5.62.0.tgz", + "integrity": "sha512-07ny+LHRzQXepkGg6w0mFY41fVUNBrL2Roj/++7V1txKugfjm/Ci/qSND03r2RhlJhJYMcTn9AhhSSqQp0Ysyw==", + "dev": true, + "requires": { + "@typescript-eslint/types": "5.62.0", + "eslint-visitor-keys": "^3.3.0" + } + }, + "eslint-scope": { + "version": "5.1.1", + "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-5.1.1.tgz", + "integrity": "sha512-2NxwbF/hZ0KpepYN0cNbo+FN6XoK7GaHlQhgx/hIZl6Va0bF45RQOOwhLIy8lQDbuCiadSLCBnH2CFYquit5bw==", + "dev": true, + "requires": { + "esrecurse": "^4.3.0", + "estraverse": "^4.1.1" + } + }, + "estraverse": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-4.3.0.tgz", + "integrity": "sha512-39nnKffWz8xN1BU/2c79n9nB9HDzo0niYUqx6xyqUnyoAnQyyWpOTdZEeiCch8BBu515t4wp9ZmgVfVhn9EBpw==", + "dev": true + }, + "lru-cache": { + "version": "6.0.0", + "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", + "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", + "dev": true, + "requires": { + "yallist": "^4.0.0" + } + }, + "semver": { + "version": "7.5.4", + "resolved": "https://registry.npmjs.org/semver/-/semver-7.5.4.tgz", + "integrity": "sha512-1bCSESV6Pv+i21Hvpxp3Dx+pSD8lIPt8uVjRrxAUt/nbswYc+tK6Y2btiULjd4+fnq15PX+nqQDC7Oft7WkwcA==", + "dev": true, + "requires": { + "lru-cache": "^6.0.0" + } + }, + "yallist": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", + "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", + "dev": true + } + } + }, + "eslint-plugin-prettier": { + "version": "5.0.1", + "resolved": "https://registry.npmjs.org/eslint-plugin-prettier/-/eslint-plugin-prettier-5.0.1.tgz", + "integrity": "sha512-m3u5RnR56asrwV/lDC4GHorlW75DsFfmUcjfCYylTUs85dBRnB7VM6xG8eCMJdeDRnppzmxZVf1GEPJvl1JmNg==", + "dev": true, + "requires": { + "prettier-linter-helpers": "^1.0.0", + "synckit": "^0.8.5" + } }, - "diff-sequences": { - "version": "29.6.3", - "resolved": "https://registry.npmjs.org/diff-sequences/-/diff-sequences-29.6.3.tgz", - "integrity": "sha512-EjePK1srD3P08o2j4f0ExnylqRs5B9tJjcp9t1krH2qRi8CCdsYfwe9JgSLurFBWwq4uOlipzfk5fHNvwFKr8Q==", - "dev": true + "eslint-scope": { + "version": "7.2.2", + "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-7.2.2.tgz", + "integrity": "sha512-dOt21O7lTMhDM+X9mB4GX+DZrZtCUJPL/wlcTqxyrx5IvO0IYtILdtrQGQp+8n5S0gwSVmOf9NQrjMOgfQZlIg==", + "dev": true, + "requires": { + "esrecurse": "^4.3.0", + "estraverse": "^5.2.0" + } }, - "electron-to-chromium": { - "version": "1.4.544", - "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.4.544.tgz", - "integrity": "sha512-54z7squS1FyFRSUqq/knOFSptjjogLZXbKcYk3B0qkE1KZzvqASwRZnY2KzZQJqIYLVD38XZeoiMRflYSwyO4w==", + "eslint-visitor-keys": { + "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==", "dev": true }, - "emittery": { - "version": "0.13.1", - "resolved": "https://registry.npmjs.org/emittery/-/emittery-0.13.1.tgz", - "integrity": "sha512-DeWwawk6r5yR9jFgnDKYt4sLS0LmHJJi3ZOnb5/JdbYwj3nW+FxQnHIjhBKz8YLC7oRNPVM9NQ47I3CVx34eqQ==", - "dev": true + "espree": { + "version": "9.6.1", + "resolved": "https://registry.npmjs.org/espree/-/espree-9.6.1.tgz", + "integrity": "sha512-oruZaFkjorTpF32kDSI5/75ViwGeZginGGy2NoOSg3Q9bnwlnmDm4HLnkl0RE3n+njDXR037aY1+x58Z/zFdwQ==", + "dev": true, + "requires": { + "acorn": "^8.9.0", + "acorn-jsx": "^5.3.2", + "eslint-visitor-keys": "^3.4.1" + } }, - "emoji-regex": { - "version": "8.0.0", - "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", - "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", + "esprima": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", + "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==", "dev": true }, - "error-ex": { - "version": "1.3.2", - "resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.2.tgz", - "integrity": "sha512-7dFHNmqeFSEt2ZBsCriorKnn3Z2pj+fd9kmI6QoWw4//DL+icEBfc0U7qJCisqrTsKTjw4fNFy2pW9OqStD84g==", + "esquery": { + "version": "1.5.0", + "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.5.0.tgz", + "integrity": "sha512-YQLXUplAwJgCydQ78IMJywZCceoqk1oH01OERdSAJc/7U2AylwjhSCLDEtqwg811idIS/9fIU5GjG73IgjKMVg==", "dev": true, "requires": { - "is-arrayish": "^0.2.1" + "estraverse": "^5.1.0" } }, - "escalade": { - "version": "3.1.1", - "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.1.1.tgz", - "integrity": "sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw==", - "dev": true + "esrecurse": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.3.0.tgz", + "integrity": "sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag==", + "dev": true, + "requires": { + "estraverse": "^5.2.0" + } }, - "escape-string-regexp": { - "version": "1.0.5", - "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", - "integrity": "sha512-vbRorB5FUQWvla16U8R/qgaFIya2qGzwDrNmCZuYKrbdSUMG6I1ZCGQRefkRVhuOkIGVne7BQ35DSfo1qvJqFg==", + "estraverse": { + "version": "5.3.0", + "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz", + "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==", "dev": true }, - "esprima": { - "version": "4.0.1", - "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", - "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==", + "esutils": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", + "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", "dev": true }, "execa": { @@ -1380,12 +2200,52 @@ "jest-util": "^29.7.0" } }, + "fast-deep-equal": { + "version": "3.1.3", + "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz", + "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==", + "dev": true + }, + "fast-diff": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/fast-diff/-/fast-diff-1.3.0.tgz", + "integrity": "sha512-VxPP4NqbUjj6MaAOafWeUn2cXWLcCtljklUtZf0Ind4XQ+QPtmA0b18zZy0jIQx+ExRVCR/ZQpBmik5lXshNsw==", + "dev": true + }, + "fast-glob": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/fast-glob/-/fast-glob-3.3.1.tgz", + "integrity": "sha512-kNFPyjhh5cKjrUltxs+wFx+ZkbRaxxmZ+X0ZU31SOsxCEtP9VPgtq2teZw1DebupL5GmDaNQ6yKMMVcM41iqDg==", + "dev": true, + "requires": { + "@nodelib/fs.stat": "^2.0.2", + "@nodelib/fs.walk": "^1.2.3", + "glob-parent": "^5.1.2", + "merge2": "^1.3.0", + "micromatch": "^4.0.4" + } + }, "fast-json-stable-stringify": { "version": "2.1.0", "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==", "dev": true }, + "fast-levenshtein": { + "version": "2.0.6", + "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", + "integrity": "sha512-DCXu6Ifhqcks7TZKY3Hxp3y6qphY5SJZmrWMDrKcERSOXWQdMhU9Ig/PYrzyw/ul9jOIyh0N4M0tbC5hodg8dw==", + "dev": true + }, + "fastq": { + "version": "1.15.0", + "resolved": "https://registry.npmjs.org/fastq/-/fastq-1.15.0.tgz", + "integrity": "sha512-wBrocU2LCXXa+lWBt8RoIRD89Fi8OdABODa/kEnyeyjS5aZO5/GNvI5sEINADqP/h8M29UHTHUb53sUu5Ihqdw==", + "dev": true, + "requires": { + "reusify": "^1.0.4" + } + }, "fb-watchman": { "version": "2.0.2", "resolved": "https://registry.npmjs.org/fb-watchman/-/fb-watchman-2.0.2.tgz", @@ -1395,6 +2255,15 @@ "bser": "2.1.1" } }, + "file-entry-cache": { + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-6.0.1.tgz", + "integrity": "sha512-7Gps/XWymbLk2QLYK4NzpMOrYjMhdIxXuIvy2QBsLE6ljuodKvdkWs/cpyJJ3CVIVpH0Oi1Hvg1ovbMzLdFBBg==", + "dev": true, + "requires": { + "flat-cache": "^3.0.4" + } + }, "fill-range": { "version": "7.0.1", "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", @@ -1419,6 +2288,23 @@ "path-exists": "^4.0.0" } }, + "flat-cache": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-3.1.1.tgz", + "integrity": "sha512-/qM2b3LUIaIgviBQovTLvijfyOQXPtSRnRK26ksj2J7rzPIecePUIpJsZ4T02Qg+xiAEKIs5K8dsHEd+VaKa/Q==", + "dev": true, + "requires": { + "flatted": "^3.2.9", + "keyv": "^4.5.3", + "rimraf": "^3.0.2" + } + }, + "flatted": { + "version": "3.2.9", + "resolved": "https://registry.npmjs.org/flatted/-/flatted-3.2.9.tgz", + "integrity": "sha512-36yxDn5H7OFZQla0/jFJmbIKTdZAQHngCedGxiMmpNfEZM0sdEeT+WczLQrjK6D7o2aiyLYDnkw0R3JK0Qv1RQ==", + "dev": true + }, "follow-redirects": { "version": "1.15.3", "resolved": "https://registry.npmjs.org/follow-redirects/-/follow-redirects-1.15.3.tgz", @@ -1485,18 +2371,47 @@ "path-is-absolute": "^1.0.0" } }, + "glob-parent": { + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", + "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", + "dev": true, + "requires": { + "is-glob": "^4.0.1" + } + }, "globals": { "version": "11.12.0", "resolved": "https://registry.npmjs.org/globals/-/globals-11.12.0.tgz", "integrity": "sha512-WOBp/EEGUiIsJSp7wcv/y6MO+lV9UoncWqxuFfm8eBwzWNgyfBd6Gz+IeKQ9jCmyhoH99g15M3T+QaVHFjizVA==", "dev": true }, + "globby": { + "version": "11.1.0", + "resolved": "https://registry.npmjs.org/globby/-/globby-11.1.0.tgz", + "integrity": "sha512-jhIXaOzy1sb8IyocaruWSn1TjmnBVs8Ayhcy83rmxNJ8q2uWKCAj3CnJY+KpGSXCueAPc0i05kVvVKtP1t9S3g==", + "dev": true, + "requires": { + "array-union": "^2.1.0", + "dir-glob": "^3.0.1", + "fast-glob": "^3.2.9", + "ignore": "^5.2.0", + "merge2": "^1.4.1", + "slash": "^3.0.0" + } + }, "graceful-fs": { "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==", "dev": true }, + "graphemer": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/graphemer/-/graphemer-1.4.0.tgz", + "integrity": "sha512-EtKwoO6kxCL9WO5xipiHTZlSzBm7WLT627TqC/uVRd0HKmq8NXyebnNYxDoBi7wt8eTWrUrKXCOVaFq9x1kgag==", + "dev": true + }, "has": { "version": "1.0.4", "resolved": "https://registry.npmjs.org/has/-/has-1.0.4.tgz", @@ -1529,6 +2444,30 @@ "ms": "^2.0.0" } }, + "ignore": { + "version": "5.2.4", + "resolved": "https://registry.npmjs.org/ignore/-/ignore-5.2.4.tgz", + "integrity": "sha512-MAb38BcSbH0eHNBxn7ql2NH/kX33OkB3lZ1BNdh7ENeRChHTYsTvWrMubiIAMNS2llXEEgZ1MUOBtXChP3kaFQ==", + "dev": true + }, + "import-fresh": { + "version": "3.3.0", + "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.0.tgz", + "integrity": "sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==", + "dev": true, + "requires": { + "parent-module": "^1.0.0", + "resolve-from": "^4.0.0" + }, + "dependencies": { + "resolve-from": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", + "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", + "dev": true + } + } + }, "import-local": { "version": "3.1.0", "resolved": "https://registry.npmjs.org/import-local/-/import-local-3.1.0.tgz", @@ -1576,6 +2515,18 @@ "has": "^1.0.3" } }, + "is-docker": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/is-docker/-/is-docker-3.0.0.tgz", + "integrity": "sha512-eljcgEDlEns/7AXFosB5K/2nCM4P7FQPkGc/DWLy5rmFEWvZayGrik1d9/QIY5nJ4f9YsVvBkA6kJpHn9rISdQ==", + "dev": true + }, + "is-extglob": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", + "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==", + "dev": true + }, "is-fullwidth-code-point": { "version": "3.0.0", "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", @@ -1588,18 +2539,59 @@ "integrity": "sha512-cTIB4yPYL/Grw0EaSzASzg6bBy9gqCofvWN8okThAYIxKJZC+udlRAmGbM0XLeniEJSs8uEgHPGuHSe1XsOLSQ==", "dev": true }, + "is-glob": { + "version": "4.0.3", + "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", + "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", + "dev": true, + "requires": { + "is-extglob": "^2.1.1" + } + }, + "is-inside-container": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-inside-container/-/is-inside-container-1.0.0.tgz", + "integrity": "sha512-KIYLCCJghfHZxqjYBE7rEy0OBuTd5xCHS7tHVgvCLkx7StIoaxwNW3hCALgEUjFfeRk+MG/Qxmp/vtETEF3tRA==", + "dev": true, + "requires": { + "is-docker": "^3.0.0" + } + }, "is-number": { "version": "7.0.0", "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", "dev": true }, + "is-path-inside": { + "version": "3.0.3", + "resolved": "https://registry.npmjs.org/is-path-inside/-/is-path-inside-3.0.3.tgz", + "integrity": "sha512-Fd4gABb+ycGAmKou8eMftCupSir5lRxqf4aD/vd0cD2qc4HL07OjCeuHMr8Ro4CoMaeCKDB0/ECBOVWjTwUvPQ==", + "dev": true + }, "is-stream": { "version": "2.0.1", "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-2.0.1.tgz", "integrity": "sha512-hFoiJiTl63nn+kstHGBtewWSKnQLpyb155KHheA1l39uvtO9nWIop1p3udqPcUd/xbF1VLMO4n7OI6p7RbngDg==", "dev": true }, + "is-wsl": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/is-wsl/-/is-wsl-2.2.0.tgz", + "integrity": "sha512-fKzAra0rGJUUBwGBgNkHZuToZcn+TtXHpeCgmkMJMMYx1sQDYaCSyjJBSCa2nH1DGm7s3n1oBnohoVTBaN7Lww==", + "dev": true, + "requires": { + "is-docker": "^2.0.0" + }, + "dependencies": { + "is-docker": { + "version": "2.2.1", + "resolved": "https://registry.npmjs.org/is-docker/-/is-docker-2.2.1.tgz", + "integrity": "sha512-F+i2BKsFrH66iaUFc0woD8sLy8getkwTwtOBjvs56Cx4CgJDeKQeqfz8wAYiSb8JOprWhHH5p77PbmYCvvUuXQ==", + "dev": true + } + } + }, "isexe": { "version": "2.0.0", "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", @@ -2191,12 +3183,30 @@ "integrity": "sha512-OYu7XEzjkCQ3C5Ps3QIZsQfNpqoJyZZA99wd9aWd05NCtC5pWOkShK2mkL6HXQR6/Cy2lbNdPlZBpuQHXE63gA==", "dev": true }, + "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==", + "dev": true + }, "json-parse-even-better-errors": { "version": "2.3.1", "resolved": "https://registry.npmjs.org/json-parse-even-better-errors/-/json-parse-even-better-errors-2.3.1.tgz", "integrity": "sha512-xyFwyhro/JEof6Ghe2iz2NcXoj2sloNsWr/XsERDK/oiPCfaNhl5ONfp+jQdAZRQQ0IJWNzH9zIZF7li91kh2w==", "dev": true }, + "json-schema-traverse": { + "version": "0.4.1", + "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", + "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", + "dev": true + }, + "json-stable-stringify-without-jsonify": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", + "integrity": "sha512-Bdboy+l7tA3OGW6FjyFHWkP5LuByj1Tk33Ljyq0axyzdk9//JSi2u3fP1QSmd1KNwq6VOKYGlAu87CisVir6Pw==", + "dev": true + }, "json-stringify-safe": { "version": "5.0.1", "resolved": "https://registry.npmjs.org/json-stringify-safe/-/json-stringify-safe-5.0.1.tgz", @@ -2215,6 +3225,15 @@ "integrity": "sha512-gfFQZrcTc8CnKXp6Y4/CBT3fTc0OVuDofpre4aEeEpSBPV5X5v4+Vmx+8snU7RLPrNHPKSgLxGo9YuQzz20o+w==", "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==", + "dev": true, + "requires": { + "json-buffer": "3.0.1" + } + }, "kleur": { "version": "3.0.3", "resolved": "https://registry.npmjs.org/kleur/-/kleur-3.0.3.tgz", @@ -2227,6 +3246,16 @@ "integrity": "sha512-qsda+H8jTaUaN/x5vzW2rzc+8Rw4TAQ/4KjB46IwK5VH+IlVeeeje/EoZRpiXvIqjFgK84QffqPztGI3VBLG1A==", "dev": true }, + "levn": { + "version": "0.4.1", + "resolved": "https://registry.npmjs.org/levn/-/levn-0.4.1.tgz", + "integrity": "sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ==", + "dev": true, + "requires": { + "prelude-ls": "^1.2.1", + "type-check": "~0.4.0" + } + }, "lines-and-columns": { "version": "1.2.4", "resolved": "https://registry.npmjs.org/lines-and-columns/-/lines-and-columns-1.2.4.tgz", @@ -2254,6 +3283,12 @@ "integrity": "sha512-t7j+NzmgnQzTAYXcsHYLgimltOV1MXHtlOWf6GjL9Kj8GK5FInw5JotxvbOs+IvV1/Dzo04/fCGfLVs7aXb4Ag==", "dev": true }, + "lodash.merge": { + "version": "4.6.2", + "resolved": "https://registry.npmjs.org/lodash.merge/-/lodash.merge-4.6.2.tgz", + "integrity": "sha512-0KpjqXRVvrYyCsX1swR/XTK0va6VQkQM6MNo7PqW77ByjAhoARA8EfrP1N4+KlKj8YS0ZUCtRT/YUuhyYDujIQ==", + "dev": true + }, "lru-cache": { "version": "5.1.1", "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-5.1.1.tgz", @@ -2331,6 +3366,12 @@ "integrity": "sha512-abv/qOcuPfk3URPfDzmZU1LKmuw8kT+0nIHvKrKgFrwifol/doWcdA4ZqsWQ8ENrFKkd67Mfpo/LovbIUsbt3w==", "dev": true }, + "merge2": { + "version": "1.4.1", + "resolved": "https://registry.npmjs.org/merge2/-/merge2-1.4.1.tgz", + "integrity": "sha512-8q7VEgMJW4J8tcfVPy8g09NcQwZdbwFEqhe/WZkoIzjn/3TGDwtOCYtXGxA3O8tPzpczCCDgv+P2P5y00ZJOOg==", + "dev": true + }, "micromatch": { "version": "4.0.5", "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-4.0.5.tgz", @@ -2381,9 +3422,9 @@ "dev": true }, "nock": { - "version": "13.3.3", - "resolved": "https://registry.npmjs.org/nock/-/nock-13.3.3.tgz", - "integrity": "sha512-z+KUlILy9SK/RjpeXDiDUEAq4T94ADPHE3qaRkf66mpEhzc/ytOMm3Bwdrbq6k1tMWkbdujiKim3G2tfQARuJw==", + "version": "13.3.4", + "resolved": "https://registry.npmjs.org/nock/-/nock-13.3.4.tgz", + "integrity": "sha512-DDpmn5oLEdCTclEqweOT4U7bEpuoifBMFUXem9sA4turDAZ5tlbrEoWqCorwXey8CaAw44mst5JOQeVNiwtkhw==", "dev": true, "requires": { "debug": "^4.1.0", @@ -2437,6 +3478,32 @@ "mimic-fn": "^2.1.0" } }, + "open": { + "version": "9.1.0", + "resolved": "https://registry.npmjs.org/open/-/open-9.1.0.tgz", + "integrity": "sha512-OS+QTnw1/4vrf+9hh1jc1jnYjzSG4ttTBB8UxOwAnInG3Uo4ssetzC1ihqaIHjLJnA5GGlRl6QlZXOTQhRBUvg==", + "dev": true, + "requires": { + "default-browser": "^4.0.0", + "define-lazy-prop": "^3.0.0", + "is-inside-container": "^1.0.0", + "is-wsl": "^2.2.0" + } + }, + "optionator": { + "version": "0.9.3", + "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.9.3.tgz", + "integrity": "sha512-JjCoypp+jKn1ttEFExxhetCKeJt9zhAgAve5FXHixTvFDW/5aEktX9bufBKLRRMdU7bNtpLfcGu94B3cdEJgjg==", + "dev": true, + "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" + } + }, "p-limit": { "version": "2.3.0", "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-2.3.0.tgz", @@ -2461,6 +3528,15 @@ "integrity": "sha512-R4nPAVTAU0B9D35/Gk3uJf/7XYbQcyohSKdvAxIRSNghFl4e71hVoGnBNQz9cWaXxO2I10KTC+3jMdvvoKw6dQ==", "dev": true }, + "parent-module": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", + "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==", + "dev": true, + "requires": { + "callsites": "^3.0.0" + } + }, "parse-json": { "version": "5.2.0", "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-5.2.0.tgz", @@ -2497,6 +3573,12 @@ "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==", "dev": true }, + "path-type": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/path-type/-/path-type-4.0.0.tgz", + "integrity": "sha512-gDKb8aZMDeD/tZWs9P6+q0J9Mwkdl6xMV8TjnGP3qJVJ06bdMgkbBlLU8IdfOsIsFz2BW1rNVT3XuNEl8zPAvw==", + "dev": true + }, "picocolors": { "version": "1.0.0", "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-1.0.0.tgz", @@ -2524,12 +3606,27 @@ "find-up": "^4.0.0" } }, + "prelude-ls": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.2.1.tgz", + "integrity": "sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==", + "dev": true + }, "prettier": { "version": "3.0.3", "resolved": "https://registry.npmjs.org/prettier/-/prettier-3.0.3.tgz", "integrity": "sha512-L/4pUDMxcNa8R/EthV08Zt42WBO4h1rarVtK0K+QJG0X187OLo7l699jWw0GKuwzkPQ//jMFA/8Xm6Fh3J/DAg==", "dev": true }, + "prettier-linter-helpers": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/prettier-linter-helpers/-/prettier-linter-helpers-1.0.0.tgz", + "integrity": "sha512-GbK2cP9nraSSUF9N2XwUwqfzlAFlMNYYl+ShE/V+H8a9uNl/oUqB1w2EL54Jh0OlyRSd8RfWYJ3coVS4TROP2w==", + "dev": true, + "requires": { + "fast-diff": "^1.1.2" + } + }, "pretty-format": { "version": "29.7.0", "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-29.7.0.tgz", @@ -2570,6 +3667,12 @@ "resolved": "https://registry.npmjs.org/proxy-from-env/-/proxy-from-env-1.1.0.tgz", "integrity": "sha512-D+zkORCbA9f1tdWRK0RaCR3GPv50cMxcrz4X8k5LTSUD1Dkw47mKJEZQNunItRTkWwgtaUSo1RVFRIG9ZXiFYg==" }, + "punycode": { + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.3.0.tgz", + "integrity": "sha512-rRV+zQD8tVFys26lAGR9WUuS4iUAngJScM+ZRSKtvl5tKeZ2t5bvdNFdNHBW9FWR4guGHlgmsZ1G7BSm2wTbuA==", + "dev": true + }, "pure-rand": { "version": "6.0.4", "resolved": "https://registry.npmjs.org/pure-rand/-/pure-rand-6.0.4.tgz", @@ -2587,6 +3690,12 @@ "strict-uri-encode": "^2.0.0" } }, + "queue-microtask": { + "version": "1.2.3", + "resolved": "https://registry.npmjs.org/queue-microtask/-/queue-microtask-1.2.3.tgz", + "integrity": "sha512-NuaNSa6flKT5JaSYQzJok04JzTL1CA6aGhv5rfLW3PgqA+M2ChpZQnAC8h8i4ZFkBS8X5RqkDBHA7r4hej3K9A==", + "dev": true + }, "react-is": { "version": "18.2.0", "resolved": "https://registry.npmjs.org/react-is/-/react-is-18.2.0.tgz", @@ -2636,6 +3745,39 @@ "resolved": "https://registry.npmjs.org/retry-axios/-/retry-axios-2.6.0.tgz", "integrity": "sha512-pOLi+Gdll3JekwuFjXO3fTq+L9lzMQGcSq7M5gIjExcl3Gu1hd4XXuf5o3+LuSBsaULQH7DiNbsqPd1chVpQGQ==" }, + "reusify": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/reusify/-/reusify-1.0.4.tgz", + "integrity": "sha512-U9nH88a3fc/ekCF1l0/UP1IosiuIjyTh7hBvXVMHYgVcfGvt897Xguj2UOLDeI5BG2m7/uwyaLVT6fbtCwTyzw==", + "dev": true + }, + "rimraf": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz", + "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==", + "dev": true, + "requires": { + "glob": "^7.1.3" + } + }, + "run-applescript": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/run-applescript/-/run-applescript-5.0.0.tgz", + "integrity": "sha512-XcT5rBksx1QdIhlFOCtgZkB99ZEouFZ1E2Kc2LHqNW13U3/74YGdkQRmThTwxy4QIyookibDKYZOPqX//6BlAg==", + "dev": true, + "requires": { + "execa": "^5.0.0" + } + }, + "run-parallel": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/run-parallel/-/run-parallel-1.2.0.tgz", + "integrity": "sha512-5l4VyZR86LZ/lDxZTR6jqL8AFE2S0IFLMP26AbjsLVADxHdhB/c0GUsH+y39UfCi3dzz8OlQuPmnaJOMoDHQBA==", + "dev": true, + "requires": { + "queue-microtask": "^1.2.2" + } + }, "semver": { "version": "6.3.1", "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.1.tgz", @@ -2799,6 +3941,24 @@ "integrity": "sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==", "dev": true }, + "synckit": { + "version": "0.8.5", + "resolved": "https://registry.npmjs.org/synckit/-/synckit-0.8.5.tgz", + "integrity": "sha512-L1dapNV6vu2s/4Sputv8xGsCdAVlb5nRDMFU/E27D44l5U6cw1g0dGd45uLc+OXjNMmF4ntiMdCimzcjFKQI8Q==", + "dev": true, + "requires": { + "@pkgr/utils": "^2.3.1", + "tslib": "^2.5.0" + }, + "dependencies": { + "tslib": { + "version": "2.6.2", + "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.6.2.tgz", + "integrity": "sha512-AEYxH93jGFPn/a2iVAwW87VuUIkR1FVUKB77NwMF7nBTDkDrrT/Hpt/IrCJ0QXhW27jTBDcf5ZY7w6RiqTMw2Q==", + "dev": true + } + } + }, "test-exclude": { "version": "6.0.0", "resolved": "https://registry.npmjs.org/test-exclude/-/test-exclude-6.0.0.tgz", @@ -2810,6 +3970,18 @@ "minimatch": "^3.0.4" } }, + "text-table": { + "version": "0.2.0", + "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", + "integrity": "sha512-N+8UisAXDGk8PFXP4HAzVR9nbfmVJ3zYLAWiTIoqC5v5isinhr+r5uaO8+7r3BMfuNIufIsA7RdpVgacC2cSpw==", + "dev": true + }, + "titleize": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/titleize/-/titleize-3.0.0.tgz", + "integrity": "sha512-KxVu8EYHDPBdUYdKZdKtU2aj2XfEx9AfjXxE/Aj0vT06w2icA09Vus1rh6eSu1y01akYg6BjIK/hxyLJINoMLQ==", + "dev": true + }, "tmpl": { "version": "1.0.5", "resolved": "https://registry.npmjs.org/tmpl/-/tmpl-1.0.5.tgz", @@ -2831,6 +4003,12 @@ "is-number": "^7.0.0" } }, + "ts-api-utils": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/ts-api-utils/-/ts-api-utils-1.0.3.tgz", + "integrity": "sha512-wNMeqtMz5NtwpT/UZGY5alT+VoKdSsOOP/kqHFcUW1P/VRhH2wJ48+DN2WwUliNbQ976ETwDL0Ifd2VVvgonvg==", + "dev": true + }, "ts-jest": { "version": "29.1.1", "resolved": "https://registry.npmjs.org/ts-jest/-/ts-jest-29.1.1.tgz", @@ -2873,6 +4051,30 @@ } } }, + "tslib": { + "version": "1.14.1", + "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.14.1.tgz", + "integrity": "sha512-Xni35NKzjgMrwevysHTCArtLDpPvye8zV/0E4EyYn43P7/7qvQwPh9BGkHewbMulVntbigmcT7rdX3BNo9wRJg==", + "dev": true + }, + "tsutils": { + "version": "3.21.0", + "resolved": "https://registry.npmjs.org/tsutils/-/tsutils-3.21.0.tgz", + "integrity": "sha512-mHKK3iUXL+3UF6xL5k0PEhKRUBKPBCv/+RkEOpjRWxxx27KKRBmmA60A9pgOUvMi8GKhRMPEmjBRPzs2W7O1OA==", + "dev": true, + "requires": { + "tslib": "^1.8.1" + } + }, + "type-check": { + "version": "0.4.0", + "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.4.0.tgz", + "integrity": "sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew==", + "dev": true, + "requires": { + "prelude-ls": "^1.2.1" + } + }, "type-detect": { "version": "4.0.8", "resolved": "https://registry.npmjs.org/type-detect/-/type-detect-4.0.8.tgz", @@ -2929,6 +4131,12 @@ "integrity": "sha512-Ga1jfYwRn7+cP9v8auvEXN1rX3sWqlayd4HP7OKk4mZWylEmu3KzXDUGrQUN6Ol7qo1gPvB2e5gX6udnyEPgdA==", "dev": true }, + "untildify": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/untildify/-/untildify-4.0.0.tgz", + "integrity": "sha512-KK8xQ1mkzZeg9inewmFVDNkg3l5LUhoq9kN6iWYB/CC9YMG8HA+c1Q8HwDe6dEX7kErrEVNVBO3fWsVq5iDgtw==", + "dev": true + }, "update-browserslist-db": { "version": "1.0.13", "resolved": "https://registry.npmjs.org/update-browserslist-db/-/update-browserslist-db-1.0.13.tgz", @@ -2939,6 +4147,15 @@ "picocolors": "^1.0.0" } }, + "uri-js": { + "version": "4.4.1", + "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.4.1.tgz", + "integrity": "sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==", + "dev": true, + "requires": { + "punycode": "^2.1.0" + } + }, "v8-to-istanbul": { "version": "9.1.3", "resolved": "https://registry.npmjs.org/v8-to-istanbul/-/v8-to-istanbul-9.1.3.tgz", diff --git a/package.json b/package.json index 934a3b69b7..3ca80b4cd8 100644 --- a/package.json +++ b/package.json @@ -44,7 +44,9 @@ "test": "jest ./src/* && npm run test:loading", "test:loading": "./test-module-loading.sh", "test:e2e": "jest ./e2e/*", - "test:all": "jest" + "test:all": "jest", + "format": "eslint . --fix", + "lint": "eslint ." }, "dependencies": { "@googlemaps/url-signature": "^1.0.4", @@ -56,9 +58,15 @@ "devDependencies": { "@types/jest": "^29.5.5", "@types/node": "^20.1.1", + "@typescript-eslint/eslint-plugin": "^6.7.4", + "@typescript-eslint/parser": "^6.7.4", + "eslint": "^8.51.0", + "eslint-config-prettier": "^9.0.0", + "eslint-plugin-jest": "^27.4.2", + "eslint-plugin-prettier": "^5.0.0", "jest": "^29.7.0", - "nock": "^13.0.4", - "prettier": "^3.0.0", + "nock": "^13.3.4", + "prettier": "^3.0.3", "ts-jest": "^29.1.1", "typedoc": "^0.25.0", "typescript": "^5.2.2" @@ -66,5 +74,8 @@ "publishConfig": { "registry": "https://wombat-dressing-room.appspot.com", "access": "public" + }, + "prettier": { + "trailingComma": "es5" } } diff --git a/src/adapter.ts b/src/adapter.ts index 39d31e6b75..fc60ba0767 100644 --- a/src/adapter.ts +++ b/src/adapter.ts @@ -17,7 +17,7 @@ import { Status } from "./common"; import axios from "axios"; -import type {AxiosResponse} from "axios"; +import type { AxiosResponse } from "axios"; export function statusToCode(status: Status): number { switch (status) { @@ -54,38 +54,43 @@ function settle(resolve, reject, response) { if (!response.status || !validateStatus || validateStatus(response.status)) { resolve(response); } else { - reject(new axios.AxiosError( - 'Request failed with status code ' + response.status, - [axios.AxiosError.ERR_BAD_REQUEST, axios.AxiosError.ERR_BAD_RESPONSE][Math.floor(response.status / 100) - 4], + reject( + new axios.AxiosError( + "Request failed with status code " + response.status, + [axios.AxiosError.ERR_BAD_REQUEST, axios.AxiosError.ERR_BAD_RESPONSE][ + Math.floor(response.status / 100) - 4 + ], response.config, response.request, response - )); + ) + ); } } - -export const customAdapter = axios.getAdapter(config => { - const httpAdapter = axios.getAdapter('http'); +export const customAdapter = axios.getAdapter((config) => { + const httpAdapter = axios.getAdapter("http"); return new Promise((resolve, reject) => { httpAdapter(config) - .then((r: AxiosResponse) => { - // unfortunately data is transformed after the adapter - let data = r.data; - if (config.transformResponse) { - const t = Array.isArray(config.transformResponse) ? config.transformResponse : [config.transformResponse]; - for (let fn of t) { - data = fn.call(config, data, r.headers, r.status); - } + .then((r: AxiosResponse) => { + // unfortunately data is transformed after the adapter + let data = r.data; + if (config.transformResponse) { + const t = Array.isArray(config.transformResponse) + ? config.transformResponse + : [config.transformResponse]; + for (const fn of t) { + data = fn.call(config, data, r.headers, r.status); } + } - if (r.status === 200 && data.status) { - r.status = statusToCode(data.status); - } + if (r.status === 200 && data.status) { + r.status = statusToCode(data.status); + } - settle(resolve, reject, r); - }) - .catch(reject); + settle(resolve, reject, r); + }) + .catch(reject); }); }); diff --git a/src/client.test.ts b/src/client.test.ts index 96dfb6d6e5..1322092aed 100644 --- a/src/client.test.ts +++ b/src/client.test.ts @@ -35,7 +35,7 @@ import { NearestRoadsRequest, SnapToRoadsRequest, X_GOOG_MAPS_EXPERIENCE_ID, - defaultAxiosInstance + defaultAxiosInstance, } from "./client"; import axios from "axios"; @@ -67,7 +67,7 @@ test("client instantiated with custom instance and config throws error", () => { expect(() => { new Client({ axiosInstance: defaultAxiosInstance, - config: { timeout: 10000 } + config: { timeout: 10000 }, }); }).toThrowError(); }); @@ -80,19 +80,21 @@ test("client can be instantiated with header options", () => { userAgent ); expect(client["axiosInstance"].defaults.headers["Accept-Encoding"]).toBe( - acceptEncoding + acceptEncoding ); }); test("client can be override Accept-Encoding with header options", () => { - const client = new Client({ config: { headers: { "x-foo": "bar", "Accept-Encoding": "identity" } } }); + const client = new Client({ + config: { headers: { "x-foo": "bar", "Accept-Encoding": "identity" } }, + }); expect(client["axiosInstance"]).toBeDefined(); expect(client["axiosInstance"].defaults.headers["x-foo"]).toEqual("bar"); expect(client["axiosInstance"].defaults.headers["User-Agent"]).toEqual( - userAgent + userAgent ); expect(client["axiosInstance"].defaults.headers["Accept-Encoding"]).toBe( - "identity" + "identity" ); }); @@ -104,7 +106,7 @@ test("client can be instantiated without header options", () => { userAgent ); expect(client["axiosInstance"].defaults.headers["Accept-Encoding"]).toBe( - acceptEncoding + acceptEncoding ); }); diff --git a/src/client.ts b/src/client.ts index 132e18eb46..bf7c943a9e 100644 --- a/src/client.ts +++ b/src/client.ts @@ -138,7 +138,7 @@ export interface ClientOptions { * ``` */ export class Client { - private axiosInstance: AxiosInstance; + private readonly axiosInstance: AxiosInstance; private experienceId: string[]; constructor({ axiosInstance, config, experienceId }: ClientOptions = {}) { @@ -168,17 +168,12 @@ export class Client { setExperienceId(...ids: string[]) { this.experienceId = ids; - this.axiosInstance.defaults.headers[X_GOOG_MAPS_EXPERIENCE_ID] = ids.join( - "," - ); + this.axiosInstance.defaults.headers[X_GOOG_MAPS_EXPERIENCE_ID] = + ids.join(","); } clearExperienceId() { this.experienceId = null; - this.clearExperienceIdHeader(); - } - - private clearExperienceIdHeader() { delete this.axiosInstance.defaults.headers[X_GOOG_MAPS_EXPERIENCE_ID]; } @@ -211,7 +206,7 @@ export class Client { * * ```javascript * import { Client } from '@googlemaps/google-maps-services-js'; - * + * * const args = { * params: { * key: '', diff --git a/src/common.ts b/src/common.ts index 787254b0e1..040ce178c8 100644 --- a/src/common.ts +++ b/src/common.ts @@ -17,7 +17,7 @@ export type RequestParams = ApiKeyParams | PremiumPlanParams; export interface ApiKeyParams { -/** + /** * You must include an API key with every API request. We strongly recommend that you restrict your API key. * Restrictions provide added security and help ensure only authorized requests are made with your API key. * @@ -436,7 +436,7 @@ export interface PlaceData { /** is a representation of the place's address in the [adr microformat](http://microformats.org/wiki/adr). */ adr_address: string; /** - * Contains a summary of the place. A summary is comprised of a textual overview, and also includes the language code + * Contains a summary of the place. A summary is comprised of a textual overview, and also includes the language code * for these if applicable. Summary text must be presented as-is and can not be modified or altered. */ editorial_summary: PlaceEditorialSummary; @@ -465,12 +465,12 @@ export interface PlaceData { plus_code: PlusCode; /** contains the URL of a suggested icon which may be displayed to the user when indicating this result on a map. */ icon: string; - /** - * The default HEX color code for the place's category. + /** + * The default HEX color code for the place's category. * @see https://developers.google.com/maps/documentation/places/web-service/icons */ icon_background_color: string; - /** + /** * The base URL for a non-colored icon, minus the file type extension (append `.svg` or `.png`). * @see https://developers.google.com/maps/documentation/places/web-service/icons */ @@ -480,7 +480,7 @@ export interface PlaceData { * International format includes the country code, and is prefixed with the plus (+) sign. * For example, the `international_phone_number` for Google's Sydney, Australia office is `+61 2 9374 4000`. */ - + international_phone_number: string; /** * contains the human-readable name for the returned result. diff --git a/src/directions.test.ts b/src/directions.test.ts index ff44a26c28..e6303b7a49 100644 --- a/src/directions.test.ts +++ b/src/directions.test.ts @@ -29,7 +29,7 @@ test("elevation should call axios correctly", () => { const params = { origin: "Seattle, WA", destination: "San Francisco, CA", - key: "foo" + key: "foo", }; directions({ params: params }, mockedAxios); @@ -39,7 +39,7 @@ test("elevation should call axios correctly", () => { method: "get", params: params, paramsSerializer: defaultParamsSerializer, - url: defaultUrl + url: defaultUrl, }); }); @@ -47,9 +47,10 @@ test("serializer should transform correctly", () => { const params = { origin: "Seattle, WA", destination: "San Francisco, CA", - key: "foo" + key: "foo", }; - expect(defaultParamsSerializer(params)) - .toEqual("destination=San%20Francisco%2C%20CA&key=foo&origin=Seattle%2C%20WA"); + expect(defaultParamsSerializer(params)).toEqual( + "destination=San%20Francisco%2C%20CA&key=foo&origin=Seattle%2C%20WA" + ); }); diff --git a/src/directions.ts b/src/directions.ts index dc26b7c86a..5675dba8ab 100644 --- a/src/directions.ts +++ b/src/directions.ts @@ -189,13 +189,16 @@ export interface DirectionsResponse extends AxiosResponse { export const defaultUrl = "https://maps.googleapis.com/maps/api/directions/json"; -export const defaultParamsSerializer = serializer({ - origin: latLngToString, - destination: latLngToString, - waypoints: (o) => o.map(latLngToString), - arrival_time: toTimestamp, - departure_time: toTimestamp, -}, defaultUrl); +export const defaultParamsSerializer = serializer( + { + origin: latLngToString, + destination: latLngToString, + waypoints: (o) => o.map(latLngToString), + arrival_time: toTimestamp, + departure_time: toTimestamp, + }, + defaultUrl +); export function directions( { diff --git a/src/distance.test.ts b/src/distance.test.ts index 72fbf00ce9..e3fcc86d86 100644 --- a/src/distance.test.ts +++ b/src/distance.test.ts @@ -18,7 +18,7 @@ import axios from "axios"; import { distancematrix, defaultParamsSerializer, - defaultUrl + defaultUrl, } from "./distance"; jest.mock("axios"); @@ -33,7 +33,7 @@ test("elevation should call axios correctly", () => { const params = { origins: ["Seattle, WA"], destinations: ["San Francisco, CA", "New York, NY"], - key: "foo" + key: "foo", }; distancematrix({ params: params }, mockedAxios); @@ -43,7 +43,7 @@ test("elevation should call axios correctly", () => { method: "get", params: params, paramsSerializer: defaultParamsSerializer, - url: defaultUrl + url: defaultUrl, }); }); @@ -51,9 +51,10 @@ test("serializer should transform correctly", () => { const params = { origins: ["Seattle, WA"], destinations: ["San Francisco, CA", "New York, NY"], - key: "foo" + key: "foo", }; - expect(defaultParamsSerializer(params)) - .toEqual("destinations=San%20Francisco%2C%20CA|New%20York%2C%20NY&key=foo&origins=Seattle%2C%20WA"); + expect(defaultParamsSerializer(params)).toEqual( + "destinations=San%20Francisco%2C%20CA|New%20York%2C%20NY&key=foo&origins=Seattle%2C%20WA" + ); }); diff --git a/src/distance.ts b/src/distance.ts index c298144b67..134cdfe9c1 100644 --- a/src/distance.ts +++ b/src/distance.ts @@ -25,7 +25,7 @@ import { TransitRoutingPreference, TravelMode, TravelRestriction, - UnitSystem + UnitSystem, } from "./common"; import { latLngToString, serializer, toTimestamp } from "./serialize"; @@ -169,12 +169,15 @@ export interface DistanceMatrixResponse extends AxiosResponse { export const defaultUrl = "https://maps.googleapis.com/maps/api/distancematrix/json"; -export const defaultParamsSerializer = serializer({ - origins: o => o.map(latLngToString), - destinations: o => o.map(latLngToString), - arrival_time: toTimestamp, - departure_time: toTimestamp -}, defaultUrl); +export const defaultParamsSerializer = serializer( + { + origins: (o) => o.map(latLngToString), + destinations: (o) => o.map(latLngToString), + arrival_time: toTimestamp, + departure_time: toTimestamp, + }, + defaultUrl +); export function distancematrix( { @@ -191,6 +194,6 @@ export function distancematrix( method, url, paramsSerializer, - ...config + ...config, }) as Promise; } diff --git a/src/elevation.test.ts b/src/elevation.test.ts index a1a364a249..9e745353bc 100644 --- a/src/elevation.test.ts +++ b/src/elevation.test.ts @@ -35,7 +35,7 @@ test("elevation should call axios correctly with location params", () => { method: "get", params: params, paramsSerializer: defaultParamsSerializer, - url: defaultUrl + url: defaultUrl, }); }); @@ -43,10 +43,10 @@ test("elevation should call axios correctly with path params", () => { const params = { path: [ { lat: 35, lng: -110 }, - { lat: 45, lng: -110 } + { lat: 45, lng: -110 }, ], samples: 10, - key: "foo" + key: "foo", }; elevation({ params: params }, mockedAxios); @@ -56,7 +56,7 @@ test("elevation should call axios correctly with path params", () => { method: "get", params: params, paramsSerializer: defaultParamsSerializer, - url: defaultUrl + url: defaultUrl, }); }); @@ -64,12 +64,13 @@ test("serializer should transform correctly", () => { const params = { path: [ { lat: 35, lng: -110 }, - { lat: 45, lng: -110 } + { lat: 45, lng: -110 }, ], samples: 10, - key: "foo" + key: "foo", }; - expect(defaultParamsSerializer(params)) - .toEqual("key=foo&path=35%2C-110|45%2C-110&samples=10"); + expect(defaultParamsSerializer(params)).toEqual( + "key=foo&path=35%2C-110|45%2C-110&samples=10" + ); }); diff --git a/src/elevation.ts b/src/elevation.ts index f29e651ba8..9a2bef9786 100644 --- a/src/elevation.ts +++ b/src/elevation.ts @@ -44,7 +44,8 @@ export interface SampledPathElevationParams { } export interface ElevationRequest extends Partial { - params: (PositionalElevationParams | SampledPathElevationParams) & RequestParams; + params: (PositionalElevationParams | SampledPathElevationParams) & + RequestParams; } export interface ElevationResponseData extends ResponseData { results: { @@ -71,10 +72,13 @@ export interface ElevationResponse extends AxiosResponse { export const defaultUrl = "https://maps.googleapis.com/maps/api/elevation/json"; -export const defaultParamsSerializer = serializer({ - locations: o => o.map(latLngToString), - path: o => o.map(latLngToString) -}, defaultUrl); +export const defaultParamsSerializer = serializer( + { + locations: (o) => o.map(latLngToString), + path: (o) => o.map(latLngToString), + }, + defaultUrl +); export function elevation( { @@ -91,6 +95,6 @@ export function elevation( method, url, paramsSerializer, - ...config + ...config, }) as Promise; } diff --git a/src/geocode/geocode.test.ts b/src/geocode/geocode.test.ts index a2f8aa8b00..1f086582a4 100644 --- a/src/geocode/geocode.test.ts +++ b/src/geocode/geocode.test.ts @@ -35,6 +35,6 @@ test("geocode should call axios correctly", () => { method: "get", params: params, paramsSerializer: defaultParamsSerializer, - url: defaultUrl + url: defaultUrl, }); }); diff --git a/src/geocode/geocode.ts b/src/geocode/geocode.ts index bb6ac1a0d3..655c7f407f 100644 --- a/src/geocode/geocode.ts +++ b/src/geocode/geocode.ts @@ -14,7 +14,12 @@ * limitations under the License. */ -import { LatLngBounds, GeocodeResult, ResponseData, RequestParams } from "../common"; +import { + LatLngBounds, + GeocodeResult, + ResponseData, + RequestParams, +} from "../common"; import { AxiosInstance, AxiosRequestConfig, AxiosResponse } from "axios"; import { defaultAxiosInstance } from "../client"; import { serializer, latLngBoundsToString, objectToString } from "../serialize"; @@ -80,7 +85,7 @@ export interface GeocodeRequest extends Partial { * Each element in the components filter consists of a `component:value` pair, and fully restricts the results from the geocoder. */ components?: string | GeocodeComponents; - } & RequestParams; + } & RequestParams; } export interface GeocodeResponseData extends ResponseData { @@ -97,10 +102,13 @@ export interface GeocodeResponse extends AxiosResponse { data: GeocodeResponseData; } -export const defaultParamsSerializer = serializer({ - bounds: latLngBoundsToString, - components: objectToString -}, defaultUrl); +export const defaultParamsSerializer = serializer( + { + bounds: latLngBoundsToString, + components: objectToString, + }, + defaultUrl +); export function geocode( { @@ -117,6 +125,6 @@ export function geocode( method, url, paramsSerializer, - ...config + ...config, }) as Promise; } diff --git a/src/geocode/reversegeocode.test.ts b/src/geocode/reversegeocode.test.ts index 2299d8be48..1b36e85ad8 100644 --- a/src/geocode/reversegeocode.test.ts +++ b/src/geocode/reversegeocode.test.ts @@ -18,7 +18,7 @@ import axios from "axios"; import { reverseGeocode, defaultParamsSerializer, - defaultUrl + defaultUrl, } from "./reversegeocode"; jest.mock("axios"); @@ -33,9 +33,9 @@ test("reverseGeocode should call axios correctly", () => { const params = { latlng: { lat: 60.168997, - lng: 24.9433353 + lng: 24.9433353, }, - key: "foo" + key: "foo", }; reverseGeocode({ params: params }, mockedAxios); @@ -45,6 +45,6 @@ test("reverseGeocode should call axios correctly", () => { method: "get", params: params, paramsSerializer: defaultParamsSerializer, - url: defaultUrl + url: defaultUrl, }); }); diff --git a/src/geocode/reversegeocode.ts b/src/geocode/reversegeocode.ts index a6c2576612..e332d36128 100644 --- a/src/geocode/reversegeocode.ts +++ b/src/geocode/reversegeocode.ts @@ -80,7 +80,7 @@ export interface ReverseGeocodeRequest extends Partial { * Note: This parameter is available only for requests that include an API key or a client ID. */ location_type?: ReverseGeocodingLocationType[]; - } & RequestParams; + } & RequestParams; } export interface ReverseGeocodeResponseData extends ResponseData { @@ -99,9 +99,12 @@ export interface ReverseGeocodeResponse extends AxiosResponse { export const defaultUrl = "https://maps.googleapis.com/maps/api/geocode/json"; -export const defaultParamsSerializer = serializer({ - latlng: latLngToString -}, defaultUrl); +export const defaultParamsSerializer = serializer( + { + latlng: latLngToString, + }, + defaultUrl +); export function reverseGeocode( { @@ -118,6 +121,6 @@ export function reverseGeocode( method, url, paramsSerializer, - ...config + ...config, }) as Promise; } diff --git a/src/geolocate.test.ts b/src/geolocate.test.ts index 44eebbcec9..58f684546a 100644 --- a/src/geolocate.test.ts +++ b/src/geolocate.test.ts @@ -35,6 +35,6 @@ test("elevation should call axios correctly", () => { method: "post", params: params, data: data, - url: defaultUrl + url: defaultUrl, }); }); diff --git a/src/geolocate.ts b/src/geolocate.ts index 6630366a45..3705fe06fe 100644 --- a/src/geolocate.ts +++ b/src/geolocate.ts @@ -21,7 +21,7 @@ import { RadioType, RequestParams, ResponseData, - WifiAccessPoint + WifiAccessPoint, } from "./common"; import { defaultAxiosInstance } from "./client"; @@ -46,7 +46,7 @@ export interface GeolocateRequest extends Partial { /** An array of WiFi access point objects. */ wifiAccessPoints?: WifiAccessPoint[]; }; - params: {} & RequestParams; + params: RequestParams; } export interface GeolocateResponseData extends ResponseData { @@ -133,6 +133,6 @@ export function geolocate( params, method, url, - ...config + ...config, }) as Promise; } diff --git a/src/places/autocomplete.test.ts b/src/places/autocomplete.test.ts index 962db1b311..a9cfd04de1 100644 --- a/src/places/autocomplete.test.ts +++ b/src/places/autocomplete.test.ts @@ -18,7 +18,7 @@ import axios from "axios"; import { placeAutocomplete, defaultParamsSerializer, - defaultUrl + defaultUrl, } from "./autocomplete"; jest.mock("axios"); @@ -39,6 +39,6 @@ test("autocomplete should call axios correctly", () => { method: "get", params: params, paramsSerializer: defaultParamsSerializer, - url: defaultUrl + url: defaultUrl, }); }); diff --git a/src/places/autocomplete.ts b/src/places/autocomplete.ts index 348ffb2587..db6fee46e3 100644 --- a/src/places/autocomplete.ts +++ b/src/places/autocomplete.ts @@ -21,7 +21,7 @@ import { PredictionTerm, RequestParams, ResponseData, - StructuredFormatting + StructuredFormatting, } from "../common"; import { AxiosInstance, AxiosRequestConfig, AxiosResponse } from "axios"; import { latLngToString, serializer } from "../serialize"; @@ -116,7 +116,7 @@ export interface PlaceAutocompleteRequest extends Partial { * will not be returned even if they match the user input. */ strictbounds?: boolean; - } & RequestParams; + } & RequestParams; } export interface PlaceAutocompleteResult { @@ -171,10 +171,13 @@ export interface PlaceAutocompleteResponse extends AxiosResponse { export const defaultUrl = "https://maps.googleapis.com/maps/api/place/autocomplete/json"; -export const defaultParamsSerializer = serializer({ - location: latLngToString, - origin: latLngToString -}, defaultUrl); +export const defaultParamsSerializer = serializer( + { + location: latLngToString, + origin: latLngToString, + }, + defaultUrl +); export function placeAutocomplete( { @@ -191,6 +194,6 @@ export function placeAutocomplete( method, url, paramsSerializer, - ...config + ...config, }) as Promise; } diff --git a/src/places/details.test.ts b/src/places/details.test.ts index 8c14c43293..5e845a0424 100644 --- a/src/places/details.test.ts +++ b/src/places/details.test.ts @@ -29,7 +29,7 @@ test("autocomplete should call axios correctly", () => { const params = { place_id: "notarealid", key: "foo", - fields: ["place_id", "name"] + fields: ["place_id", "name"], }; placeDetails({ params: params }, mockedAxios); @@ -39,6 +39,6 @@ test("autocomplete should call axios correctly", () => { method: "get", params: params, paramsSerializer: defaultParamsSerializer, - url: defaultUrl + url: defaultUrl, }); }); diff --git a/src/places/details.ts b/src/places/details.ts index 566003c559..e4480cd50b 100644 --- a/src/places/details.ts +++ b/src/places/details.ts @@ -52,7 +52,7 @@ export interface PlaceDetailsRequest extends Partial { * This applies only to Place Details requests. */ fields?: string[]; - } & RequestParams; + } & RequestParams; } export interface PlaceDetailsResponseData extends ResponseData { result: Place; @@ -67,7 +67,9 @@ export interface PlaceDetailsResponse extends AxiosResponse { export const defaultUrl = "https://maps.googleapis.com/maps/api/place/details/json"; -export const defaultParamsSerializer = serializer({}, defaultUrl, {arrayFormat: "comma"}); +export const defaultParamsSerializer = serializer({}, defaultUrl, { + arrayFormat: "comma", +}); export function placeDetails( { @@ -84,6 +86,6 @@ export function placeDetails( method, url, paramsSerializer, - ...config + ...config, }) as Promise; } diff --git a/src/places/findplacefromtext.test.ts b/src/places/findplacefromtext.test.ts index ce3e5b7940..4e066b6ead 100644 --- a/src/places/findplacefromtext.test.ts +++ b/src/places/findplacefromtext.test.ts @@ -18,7 +18,7 @@ import axios from "axios"; import { findPlaceFromText, defaultParamsSerializer, - defaultUrl + defaultUrl, } from "./findplacefromtext"; import { PlaceInputType } from "../common"; @@ -35,7 +35,7 @@ test("autocomplete should call axios correctly", () => { input: "google", inputtype: PlaceInputType.textQuery, key: "foo", - fields: ["place_id", "name"] + fields: ["place_id", "name"], }; findPlaceFromText({ params: params }, mockedAxios); @@ -45,6 +45,6 @@ test("autocomplete should call axios correctly", () => { method: "get", params: params, paramsSerializer: defaultParamsSerializer, - url: defaultUrl + url: defaultUrl, }); }); diff --git a/src/places/findplacefromtext.ts b/src/places/findplacefromtext.ts index dcaa67948f..29264ba289 100644 --- a/src/places/findplacefromtext.ts +++ b/src/places/findplacefromtext.ts @@ -14,7 +14,13 @@ * limitations under the License. */ -import { Language, ResponseData, Place, PlaceInputType, RequestParams } from "../common"; +import { + Language, + ResponseData, + Place, + PlaceInputType, + RequestParams, +} from "../common"; import { AxiosInstance, AxiosRequestConfig, AxiosResponse } from "axios"; import { defaultAxiosInstance } from "../client"; import { serializer } from "../serialize"; @@ -41,7 +47,7 @@ export interface FindPlaceFromTextRequest extends Partial { * the points of a rectangle. If this parameter is not specified, the API uses IP address biasing by default. */ locationbias?: string; - } & RequestParams; + } & RequestParams; } export interface FindPlaceFromTextResponseData extends ResponseData { @@ -55,7 +61,9 @@ export interface FindPlaceFromTextResponse extends AxiosResponse { export const defaultUrl = "https://maps.googleapis.com/maps/api/place/findplacefromtext/json"; -export const defaultParamsSerializer = serializer({}, defaultUrl, {arrayFormat: "comma"}); +export const defaultParamsSerializer = serializer({}, defaultUrl, { + arrayFormat: "comma", +}); export function findPlaceFromText( { @@ -72,6 +80,6 @@ export function findPlaceFromText( method, url, paramsSerializer, - ...config + ...config, }) as Promise; } diff --git a/src/places/photo.test.ts b/src/places/photo.test.ts index a79a535b21..53e920d137 100644 --- a/src/places/photo.test.ts +++ b/src/places/photo.test.ts @@ -27,7 +27,7 @@ afterEach(() => { test("photo should call axios correctly", () => { const params = { photoreference: "notaphotoreference", key: "foo" }; - const responseType = 'arraybuffer'; + const responseType = "arraybuffer"; placePhoto({ params, responseType }, mockedAxios); expect(mockedAxios).toHaveBeenCalledTimes(1); diff --git a/src/places/photo.ts b/src/places/photo.ts index 70474cd1e1..ece309c3fd 100644 --- a/src/places/photo.ts +++ b/src/places/photo.ts @@ -39,8 +39,8 @@ export interface PlacePhotoRequest extends Partial { * restricted to its original aspect ratio. Both the `maxheight` and `maxwidth` properties accept an integer between 1 and 1600. */ maxheight?: number; - } & RequestParams; - responseType: 'arraybuffer' | 'blob' | 'stream'; + } & RequestParams; + responseType: "arraybuffer" | "blob" | "stream"; } /** @@ -60,11 +60,17 @@ export interface PlacePhotoResponse extends AxiosResponse {} export const defaultUrl = "https://maps.googleapis.com/maps/api/place/photo"; export function placePhoto( - { params, method = "get", url = defaultUrl, responseType, ...config }: PlacePhotoRequest, + { + params, + method = "get", + url = defaultUrl, + responseType, + ...config + }: PlacePhotoRequest, axiosInstance: AxiosInstance = defaultAxiosInstance ): Promise { if (!responseType) { - responseType = 'arraybuffer' + responseType = "arraybuffer"; } return axiosInstance({ @@ -72,6 +78,6 @@ export function placePhoto( method, url, responseType, - ...config + ...config, }) as Promise; } diff --git a/src/places/placesnearby.test.ts b/src/places/placesnearby.test.ts index 31e7117adc..68efbd1c34 100644 --- a/src/places/placesnearby.test.ts +++ b/src/places/placesnearby.test.ts @@ -18,7 +18,7 @@ import { PlacesNearbyRanking, defaultParamsSerializer, defaultUrl, - placesNearby + placesNearby, } from "./placesnearby"; import axios from "axios"; @@ -35,7 +35,7 @@ test("autocomplete should call axios correctly", () => { const params = { location: { lat: 35, lng: -110 }, key: "foo", - ranking: PlacesNearbyRanking.distance + ranking: PlacesNearbyRanking.distance, }; placesNearby({ params: params }, mockedAxios); @@ -45,6 +45,6 @@ test("autocomplete should call axios correctly", () => { method: "get", params: params, url: defaultUrl, - paramsSerializer: defaultParamsSerializer + paramsSerializer: defaultParamsSerializer, }); }); diff --git a/src/places/placesnearby.ts b/src/places/placesnearby.ts index e4576b0799..1560328310 100644 --- a/src/places/placesnearby.ts +++ b/src/places/placesnearby.ts @@ -115,7 +115,10 @@ export interface PlacesNearbyResponse extends AxiosResponse { export const defaultUrl = "https://maps.googleapis.com/maps/api/place/nearbysearch/json"; -export const defaultParamsSerializer = serializer({ location: latLngToString }, defaultUrl); +export const defaultParamsSerializer = serializer( + { location: latLngToString }, + defaultUrl +); export function placesNearby( { diff --git a/src/places/queryautocomplete.test.ts b/src/places/queryautocomplete.test.ts index e2eb41420e..dea81dc50b 100644 --- a/src/places/queryautocomplete.test.ts +++ b/src/places/queryautocomplete.test.ts @@ -18,7 +18,7 @@ import axios from "axios"; import { placeQueryAutocomplete, defaultParamsSerializer, - defaultUrl + defaultUrl, } from "./queryautocomplete"; jest.mock("axios"); @@ -39,6 +39,6 @@ test("autocomplete should call axios correctly", () => { method: "get", params: params, paramsSerializer: defaultParamsSerializer, - url: defaultUrl + url: defaultUrl, }); }); diff --git a/src/places/queryautocomplete.ts b/src/places/queryautocomplete.ts index 9b2c37036c..ed9a7b9330 100644 --- a/src/places/queryautocomplete.ts +++ b/src/places/queryautocomplete.ts @@ -17,12 +17,11 @@ import { LatLng, Language, - Place, ResponseData, RequestParams, PredictionTerm, PredictionSubstring, - StructuredFormatting + StructuredFormatting, } from "../common"; import { AxiosInstance, AxiosRequestConfig, AxiosResponse } from "axios"; import { defaultAxiosInstance } from "../client"; @@ -93,7 +92,10 @@ export interface PlaceQueryAutocompleteResponse extends AxiosResponse { export const defaultUrl = "https://maps.googleapis.com/maps/api/place/queryautocomplete/json"; -export const defaultParamsSerializer = serializer({ location: latLngToString }, defaultUrl); +export const defaultParamsSerializer = serializer( + { location: latLngToString }, + defaultUrl +); export function placeQueryAutocomplete( { @@ -110,6 +112,6 @@ export function placeQueryAutocomplete( method, url, paramsSerializer, - ...config + ...config, }) as Promise; } diff --git a/src/places/textsearch.test.ts b/src/places/textsearch.test.ts index 8071f1a290..1d35502efb 100644 --- a/src/places/textsearch.test.ts +++ b/src/places/textsearch.test.ts @@ -35,6 +35,6 @@ test("textsearch should call axios correctly", () => { method: "get", params: params, paramsSerializer: defaultParamsSerializer, - url: defaultUrl + url: defaultUrl, }); }); diff --git a/src/places/textsearch.ts b/src/places/textsearch.ts index c89c368222..442e3c0d61 100644 --- a/src/places/textsearch.ts +++ b/src/places/textsearch.ts @@ -14,7 +14,14 @@ * limitations under the License. */ -import { ResponseData, LatLng, Language, PlaceType1, Place, RequestParams } from "../common"; +import { + ResponseData, + LatLng, + Language, + PlaceType1, + Place, + RequestParams, +} from "../common"; import { AxiosInstance, AxiosRequestConfig, AxiosResponse } from "axios"; import { defaultAxiosInstance } from "../client"; import { serializer, latLngToString } from "../serialize"; @@ -84,7 +91,7 @@ export interface TextSearchRequest extends Partial { * Only one type may be specified (if more than one type is provided, all types following the first entry are ignored). */ type?: PlaceType1; - } & RequestParams; + } & RequestParams; } export interface TextSearchResponseData extends ResponseData { @@ -98,7 +105,10 @@ export interface TextSearchResponse extends AxiosResponse { export const defaultUrl = "https://maps.googleapis.com/maps/api/place/textsearch/json"; -export const defaultParamsSerializer = serializer({ location: latLngToString }, defaultUrl); +export const defaultParamsSerializer = serializer( + { location: latLngToString }, + defaultUrl +); export function textSearch( { @@ -115,6 +125,6 @@ export function textSearch( method, url, paramsSerializer, - ...config + ...config, }) as Promise; } diff --git a/src/roads/nearestroads.test.ts b/src/roads/nearestroads.test.ts index 88d17be696..1c4e5d74cb 100644 --- a/src/roads/nearestroads.test.ts +++ b/src/roads/nearestroads.test.ts @@ -18,7 +18,7 @@ import axios from "axios"; import { nearestRoads, defaultParamsSerializer, - defaultUrl + defaultUrl, } from "./nearestroads"; jest.mock("axios"); @@ -39,13 +39,12 @@ test("nearestRoads should call axios correctly", () => { method: "get", params: params, paramsSerializer: defaultParamsSerializer, - url: defaultUrl + url: defaultUrl, }); }); test("serializer should transform correctly", () => { const params = { points: ["0,0"], key: "foo" }; - expect(defaultParamsSerializer(params)) - .toEqual("key=foo&points=0%2C0"); + expect(defaultParamsSerializer(params)).toEqual("key=foo&points=0%2C0"); }); diff --git a/src/roads/nearestroads.ts b/src/roads/nearestroads.ts index bd043fa743..f788d159bd 100644 --- a/src/roads/nearestroads.ts +++ b/src/roads/nearestroads.ts @@ -27,7 +27,7 @@ export interface NearestRoadsRequest extends Partial { * For example: `points=60.170880,24.942795|60.170879,24.942796|60.170877,24.942796`. */ points: LatLng[]; - } & RequestParams; + } & RequestParams; } export interface NearestRoadsResponse extends AxiosResponse { @@ -38,9 +38,12 @@ export interface NearestRoadsResponse extends AxiosResponse { } export const defaultUrl = "https://roads.googleapis.com/v1/nearestRoads"; -export const defaultParamsSerializer = serializer({ - points: o => o.map(latLng => latLngToString(latLng)) -}, defaultUrl); +export const defaultParamsSerializer = serializer( + { + points: (o) => o.map((latLng) => latLngToString(latLng)), + }, + defaultUrl +); export function nearestRoads( { @@ -57,6 +60,6 @@ export function nearestRoads( method, url, paramsSerializer, - ...config + ...config, }) as Promise; } diff --git a/src/roads/snaptoroads.test.ts b/src/roads/snaptoroads.test.ts index dc5f7e8b98..0fa0c1eae6 100644 --- a/src/roads/snaptoroads.test.ts +++ b/src/roads/snaptoroads.test.ts @@ -18,7 +18,7 @@ import axios from "axios"; import { snapToRoads, defaultParamsSerializer, - defaultUrl + defaultUrl, } from "./snaptoroads"; jest.mock("axios"); @@ -39,13 +39,12 @@ test("snapToRoads should call axios correctly", () => { method: "get", params: params, paramsSerializer: defaultParamsSerializer, - url: defaultUrl + url: defaultUrl, }); }); test("serializer should transform correctly", () => { const params = { path: ["0,0"], key: "foo" }; - expect(defaultParamsSerializer(params)) - .toEqual("key=foo&path=0%2C0"); + expect(defaultParamsSerializer(params)).toEqual("key=foo&path=0%2C0"); }); diff --git a/src/roads/snaptoroads.ts b/src/roads/snaptoroads.ts index dd4c986644..29dadce012 100644 --- a/src/roads/snaptoroads.ts +++ b/src/roads/snaptoroads.ts @@ -42,7 +42,7 @@ export interface SnapToRoadsRequest extends Partial { * @default false */ interpolate?: boolean; - } & RequestParams; + } & RequestParams; } export interface SnapToRoadsResponse extends AxiosResponse { @@ -52,9 +52,12 @@ export interface SnapToRoadsResponse extends AxiosResponse { }; } export const defaultUrl = "https://roads.googleapis.com/v1/snapToRoads"; -export const defaultParamsSerializer = serializer({ - path: o => o.map(latLngToString) -}, defaultUrl); +export const defaultParamsSerializer = serializer( + { + path: (o) => o.map(latLngToString), + }, + defaultUrl +); export function snapToRoads( { @@ -71,6 +74,6 @@ export function snapToRoads( method, url, paramsSerializer, - ...config + ...config, }) as Promise; } diff --git a/src/serialize.test.ts b/src/serialize.test.ts index a845696375..9ddaafdad5 100644 --- a/src/serialize.test.ts +++ b/src/serialize.test.ts @@ -48,11 +48,16 @@ test("latLngBoundsToString is correct", () => { }); test("serializer", () => { - expect(serializer({ quz: (o) => o }, "http://mock.url")({ foo: ["bar"] })).toBe("foo=bar"); expect( - serializer({ - foo: (o) => o.map((latLng: LatLng) => latLngToString(latLng)), - }, "http://mock.url")({ + serializer({ quz: (o) => o }, "http://mock.url")({ foo: ["bar"] }) + ).toBe("foo=bar"); + expect( + serializer( + { + foo: (o) => o.map((latLng: LatLng) => latLngToString(latLng)), + }, + "http://mock.url" + )({ foo: [ [0, 1], [2, 3], @@ -72,10 +77,11 @@ test("serializer should not mutate params", () => { }); test("serializer should return pipe joined arrays by default", () => { - expect(serializer({}, "http://mock.url")({ foo: ["b", "a", "r"] })).toBe("foo=b|a|r"); + expect(serializer({}, "http://mock.url")({ foo: ["b", "a", "r"] })).toBe( + "foo=b|a|r" + ); }); - test("serializer creates premium plan query string if premium plan params are included", () => { const params = { avoid: "ferries", @@ -93,11 +99,17 @@ test("serializer creates premium plan query string if premium plan params are in client_secret: "testClientSecret", }; - expect(serializer({ - origin: latLngToString, - destination: latLngToString, - }, "https://test.url/maps/api/directions/json")(params)) - .toEqual('avoid=ferries&client=testClient&destination=38.8977%2C-77.0365&mode=driving&origin=33.8121%2C-117.9190&units=imperial&signature=YRJoTd6ohbpsR14WkWv3S7H6MqU='); + expect( + serializer( + { + origin: latLngToString, + destination: latLngToString, + }, + "https://test.url/maps/api/directions/json" + )(params) + ).toEqual( + "avoid=ferries&client=testClient&destination=38.8977%2C-77.0365&mode=driving&origin=33.8121%2C-117.9190&units=imperial&signature=YRJoTd6ohbpsR14WkWv3S7H6MqU=" + ); }); test("objectToString", () => { @@ -140,7 +152,7 @@ test("toTimestamp", () => { expect(toTimestamp(dt)).toEqual(seconds); expect(toTimestamp("now")).toEqual("now"); - expect(toTimestamp(new Date('2022-06-22T09:03:33.430Z'))).toEqual(1655888613); + expect(toTimestamp(new Date("2022-06-22T09:03:33.430Z"))).toEqual(1655888613); }); test("createPremiumPlanQueryString", () => { @@ -159,6 +171,9 @@ test("createPremiumPlanQueryString", () => { }; const baseUrl = "https://test.url/maps/api/directions/json"; - expect(createPremiumPlanQueryString(serializedParams, queryStringOptions, baseUrl)) - .toEqual('avoid=ferries&client=testClient&destination=38.8977%2C-77.0365&mode=driving&origin=33.8121%2C-117.9190&units=imperial&signature=YRJoTd6ohbpsR14WkWv3S7H6MqU='); + expect( + createPremiumPlanQueryString(serializedParams, queryStringOptions, baseUrl) + ).toEqual( + "avoid=ferries&client=testClient&destination=38.8977%2C-77.0365&mode=driving&origin=33.8121%2C-117.9190&units=imperial&signature=YRJoTd6ohbpsR14WkWv3S7H6MqU=" + ); }); diff --git a/src/serialize.ts b/src/serialize.ts index 865ef0f5a9..4d5f794447 100644 --- a/src/serialize.ts +++ b/src/serialize.ts @@ -17,8 +17,8 @@ import { LatLng, LatLngBounds, LatLngLiteral } from "./common"; import { encodePath } from "./util"; -import {createSignature} from "@googlemaps/url-signature"; -import queryString from 'query-string'; +import { createSignature } from "@googlemaps/url-signature"; +import queryString from "query-string"; const qs = queryString.stringify; @@ -48,7 +48,7 @@ export function objectToString(o: string | object): string { if (typeof o === "string") { return o; } else { - let keys = Object.keys(o); + const keys = Object.keys(o); keys.sort(); return keys.map((k) => k + ":" + o[k]).join(separator); } @@ -108,19 +108,27 @@ export function serializer( arrayFormatSeparator: separator, } ) { - return (params: { [key: string]: any }) => { + // eslint-disable-next-line @typescript-eslint/no-explicit-any + return (params: Record) => { // avoid mutating params const serializedParams = { ...params }; - Object.keys(format).forEach((key: string) => { + for (const key of Object.keys(format)) { if (key in serializedParams) { serializedParams[key] = format[key](serializedParams[key]); } - }); + } - if ("client_id" in serializedParams && "client_secret" in serializedParams) { + if ( + "client_id" in serializedParams && + "client_secret" in serializedParams + ) { // Special case to handle premium plan signature - return createPremiumPlanQueryString(serializedParams, queryStringOptions, baseUrl); + return createPremiumPlanQueryString( + serializedParams, + queryStringOptions, + baseUrl + ); } return qs(serializedParams, queryStringOptions); @@ -140,7 +148,7 @@ export function toTimestamp(o: "now" | number | Date): number | "now" { export function createPremiumPlanQueryString( serializedParams: { [key: string]: string }, queryStringOptions: object, - baseUrl: string, + baseUrl: string ): string { serializedParams.client = serializedParams.client_id; const clientSecret = serializedParams.client_secret; @@ -149,7 +157,7 @@ export function createPremiumPlanQueryString( const partialQueryString = qs(serializedParams, queryStringOptions); const unsignedUrl = `${baseUrl}?${partialQueryString}`; - const signature = createSignature(unsignedUrl, clientSecret); + const signature = createSignature(unsignedUrl, clientSecret); // The signature must come last return `${partialQueryString}&signature=${signature}`; diff --git a/src/timezone.test.ts b/src/timezone.test.ts index b3720f71d2..649a26ca96 100644 --- a/src/timezone.test.ts +++ b/src/timezone.test.ts @@ -30,7 +30,7 @@ test("elevation should call axios correctly", () => { const params = { location: { lat: 35, lng: -110 }, timestamp: 999999999, - key: "foo" + key: "foo", }; timezone({ params: params }, mockedAxios); @@ -39,11 +39,13 @@ test("elevation should call axios correctly", () => { method: "get", params: params, paramsSerializer: defaultParamsSerializer, - url: defaultUrl + url: defaultUrl, }); }); test("serializer should handle date object", () => { const dt = new Date(); - expect(defaultParamsSerializer({timestamp: dt})).toEqual(`timestamp=${Math.round(Number(dt)/1000)}`) + expect(defaultParamsSerializer({ timestamp: dt })).toEqual( + `timestamp=${Math.round(Number(dt) / 1000)}` + ); }); diff --git a/src/timezone.ts b/src/timezone.ts index e3f4ab5d96..a333607651 100644 --- a/src/timezone.ts +++ b/src/timezone.ts @@ -71,10 +71,13 @@ export interface TimeZoneResponse extends AxiosResponse { } export const defaultUrl = "https://maps.googleapis.com/maps/api/timezone/json"; -export const defaultParamsSerializer = serializer({ - timestamp: toTimestamp, - location: latLngToString -}, defaultUrl); +export const defaultParamsSerializer = serializer( + { + timestamp: toTimestamp, + location: latLngToString, + }, + defaultUrl +); export function timezone( { params, @@ -90,6 +93,6 @@ export function timezone( method, url, paramsSerializer, - ...config + ...config, }) as Promise; } diff --git a/src/util.test.ts b/src/util.test.ts index 0b87405e39..0a78d40282 100644 --- a/src/util.test.ts +++ b/src/util.test.ts @@ -22,72 +22,72 @@ describe("polyline encoding and decoding is correct", () => { const decoded = [ { lat: 53.489320000000006, - lng: -104.16777 + lng: -104.16777, }, { lat: 53.490140000000004, - lng: -104.16833000000001 + lng: -104.16833000000001, }, { lat: 53.490700000000004, - lng: -104.16936000000001 + lng: -104.16936000000001, }, { lat: 53.49065, - lng: -104.17142000000001 + lng: -104.17142000000001, }, { lat: 53.49011, - lng: -104.17288 + lng: -104.17288, }, { lat: 53.488760000000006, - lng: -104.17305 + lng: -104.17305, }, { lat: 53.48715000000001, - lng: -104.17219000000001 + lng: -104.17219000000001, }, { lat: 53.485420000000005, - lng: -104.17022000000001 + lng: -104.17022000000001, }, { lat: 53.483450000000005, - lng: -104.1679 + lng: -104.1679, }, { lat: 53.48554000000001, - lng: -104.16442 + lng: -104.16442, }, { lat: 53.487100000000005, - lng: -104.16279000000002 + lng: -104.16279000000002, }, { lat: 53.48863000000001, - lng: -104.16236 + lng: -104.16236, }, { lat: 53.49004000000001, - lng: -104.16249 + lng: -104.16249, }, { lat: 53.490550000000006, - lng: -104.16361 + lng: -104.16361, }, { lat: 53.49083, - lng: -104.16477 + lng: -104.16477, }, { lat: 53.49045, - lng: -104.16648 + lng: -104.16648, }, { lat: 53.48935, - lng: -104.16773 - } + lng: -104.16773, + }, ]; test("encodePath is correct", () => { diff --git a/src/util.ts b/src/util.ts index 2454af1134..fe8c033eb7 100644 --- a/src/util.ts +++ b/src/util.ts @@ -23,11 +23,11 @@ import { LatLngLiteral } from "./common"; * */ export function encodePath(path: LatLngLiteral[]): string { - var result: string[] = []; - var start: [number, number] = [0, 0]; - var end: [number, number]; + const result: string[] = []; + let start: [number, number] = [0, 0]; + let end: [number, number]; - var encodePart = function(part: number) { + const encodePart = function (part: number) { part = part < 0 ? ~(part << 1) : part << 1; while (part >= 0x20) { result.push(String.fromCharCode((0x20 | (part & 0x1f)) + 63)); @@ -52,8 +52,8 @@ export function encodePath(path: LatLngLiteral[]): string { * See {@link https://developers.google.com/maps/documentation/utilities/polylinealgorithm} */ export function decodePath(encodedPath: string): LatLngLiteral[] { - let len: number = encodedPath.length || 0; - let path = new Array(Math.floor(encodedPath.length / 2)); + const len: number = encodedPath.length || 0; + const path = new Array(Math.floor(encodedPath.length / 2)); let index: number = 0; let lat: number = 0; let lng: number = 0; diff --git a/typedoc.js b/typedoc.js index 28859bbb63..e16748f94d 100644 --- a/typedoc.js +++ b/typedoc.js @@ -18,5 +18,5 @@ module.exports = { out: "docs", exclude: ["**/node_modules/**", "**/*.spec.ts", "**/*.test.ts", "dist"], name: "Google Maps Services Node Client", - readme: "./README.md" -}; \ No newline at end of file + readme: "./README.md", +};