From bea98e0ec310fb17fe88950c110f19ab1c46ee20 Mon Sep 17 00:00:00 2001 From: "shai.ungar" Date: Sat, 21 Sep 2024 19:18:17 +0300 Subject: [PATCH 01/16] make tests pass --- package.json | 5 +- packages/renderer/src/components/App.test.tsx | 6 +- .../src/components/accounts/Importers.tsx | 2 +- .../components/exporters/EditFileExporter.tsx | 2 +- .../components/exporters/EditYnabExporter.tsx | 2 +- .../components/topBar/ReportProblemModal.tsx | 2 +- .../renderer/src/components/topBar/TopBar.tsx | 2 +- packages/renderer/src/setupTests.ts | 4 + packages/renderer/src/store/ConfigStore.tsx | 2 +- packages/renderer/src/store/Store.test.tsx | 49 +- .../store/__snapshots__/Store.test.tsx.snap | 125 ++ packages/renderer/src/types.tsx | 1 - packages/renderer/tsconfig.json | 4 +- packages/renderer/vitest-setup.js | 29 + packages/renderer/vitest.config.js | 19 + vitest-setup.js | 25 + vitest.base.config.js | 7 + vitest.config.js | 7 +- yarn.lock | 1038 ++++++++++++++--- 19 files changed, 1135 insertions(+), 196 deletions(-) create mode 100644 packages/renderer/src/store/__snapshots__/Store.test.tsx.snap create mode 100644 packages/renderer/vitest-setup.js create mode 100644 packages/renderer/vitest.config.js create mode 100644 vitest.base.config.js diff --git a/package.json b/package.json index d5038173..ac3d4c6b 100644 --- a/package.json +++ b/package.json @@ -61,7 +61,8 @@ "typescript": "5.4.5", "unplugin-auto-expose": "0.3.0", "vite": "5.2.14", - "vitest": "^2.0.5" + "vite-tsconfig-paths": "^5.0.1", + "vitest": "^2.1.1" }, "dependencies": { "@puppeteer/browsers": "^2.2.3", @@ -92,6 +93,8 @@ "react-bootstrap-table2-editor": "^1.4.0", "react-bootstrap-typeahead": "^6.3.2", "react-dom": "^18.3.1", + "svelte": "^4.2.19", + "vite-plugin-node-polyfills": "^0.22.0", "web-vitals": "^4.2.0", "ynab": "^1.19.0" } diff --git a/packages/renderer/src/components/App.test.tsx b/packages/renderer/src/components/App.test.tsx index a7765a4f..ad9a4098 100644 --- a/packages/renderer/src/components/App.test.tsx +++ b/packages/renderer/src/components/App.test.tsx @@ -2,8 +2,8 @@ import { render, screen } from '@testing-library/react'; import { expect, test } from 'vitest'; import App from './App'; -test('renders learn react link', () => { +test('renders discord link', () => { render(); - const linkElement = screen.getByText(/learn react/i); - expect(linkElement).toBeInTheDocument(); + const linkElement = screen.getByText(/ערוץ הדיסקורד שלנו/i); + expect(linkElement).to.exist; }); diff --git a/packages/renderer/src/components/accounts/Importers.tsx b/packages/renderer/src/components/accounts/Importers.tsx index 25a622c5..b2e6e241 100644 --- a/packages/renderer/src/components/accounts/Importers.tsx +++ b/packages/renderer/src/components/accounts/Importers.tsx @@ -9,7 +9,7 @@ import { } from '../../types'; import Account, { type ActionButton } from './Account'; import NewAccount from './NewAccount'; -import { useConfigStore } from '/@/store/ConfigStore'; +import { useConfigStore } from '../../store/ConfigStore'; interface ImportersProps { accounts: AccountType[]; diff --git a/packages/renderer/src/components/exporters/EditFileExporter.tsx b/packages/renderer/src/components/exporters/EditFileExporter.tsx index c692365a..cc997056 100644 --- a/packages/renderer/src/components/exporters/EditFileExporter.tsx +++ b/packages/renderer/src/components/exporters/EditFileExporter.tsx @@ -2,7 +2,7 @@ import { showSaveDialog } from '#preload'; import { observer } from 'mobx-react-lite'; import React, { useState } from 'react'; import { Button, Card, Form, Image } from 'react-bootstrap'; -import { type Exporter } from '../../types'; +import { type Exporter } from '/@/types'; import styles from './EditFileExporter.module.css'; interface EditFileExporterProps { diff --git a/packages/renderer/src/components/exporters/EditYnabExporter.tsx b/packages/renderer/src/components/exporters/EditYnabExporter.tsx index f9001e87..f6afc7e4 100644 --- a/packages/renderer/src/components/exporters/EditYnabExporter.tsx +++ b/packages/renderer/src/components/exporters/EditYnabExporter.tsx @@ -7,7 +7,7 @@ import { type YnabConfig } from '../../types'; import styles from './EditYnabExporter.module.css'; import YnabAccountMappingTable from './YnabAccountMappingTable'; -import { useStore } from '/@/store'; +import { useStore } from '../../store'; interface EditYnabExporterProps { handleSave: (exporterConfig: YnabConfig) => Promise; diff --git a/packages/renderer/src/components/topBar/ReportProblemModal.tsx b/packages/renderer/src/components/topBar/ReportProblemModal.tsx index 2ee1de70..55e47fad 100644 --- a/packages/renderer/src/components/topBar/ReportProblemModal.tsx +++ b/packages/renderer/src/components/topBar/ReportProblemModal.tsx @@ -6,7 +6,7 @@ import { Button, Col, Form, Modal, Row, Stack } from 'react-bootstrap'; import { isValidEmail } from '../../utils/validations'; import { getZIndexes } from '../../utils/zIndexesManager'; import LogsCanvas from './LogsCanvas'; -import { useAppInfoStore } from '/@/store'; +import { useAppInfoStore } from '../../store'; const NUM_OF_LAST_LINES = 10; diff --git a/packages/renderer/src/components/topBar/TopBar.tsx b/packages/renderer/src/components/topBar/TopBar.tsx index fe238867..daf8c85e 100644 --- a/packages/renderer/src/components/topBar/TopBar.tsx +++ b/packages/renderer/src/components/topBar/TopBar.tsx @@ -7,7 +7,7 @@ import logo from '../../assets/logoFishOnly.svg'; import NavButton from './NavButton'; import ReportProblemModal from './ReportProblemModal'; import styles from './TopBar.module.css'; -import { useAppInfoStore } from '/@/store'; +import { useAppInfoStore } from '../../store'; function TopBar() { const [show, setShow] = useState(false); diff --git a/packages/renderer/src/setupTests.ts b/packages/renderer/src/setupTests.ts index 35d8c236..13fae2d5 100644 --- a/packages/renderer/src/setupTests.ts +++ b/packages/renderer/src/setupTests.ts @@ -10,6 +10,10 @@ const MOCK_ELECTRON = { invoke: () => {}, send: () => {}, }, + shell: { + openExternal: () => {}, + openPath: () => {}, + }, }; // @ts-expect-error - this is a mock diff --git a/packages/renderer/src/store/ConfigStore.tsx b/packages/renderer/src/store/ConfigStore.tsx index 8e90c38b..cf32f058 100644 --- a/packages/renderer/src/store/ConfigStore.tsx +++ b/packages/renderer/src/store/ConfigStore.tsx @@ -14,7 +14,7 @@ import { type Exporter, type Importer, type Log, - type OutputVendorName, + type OutputVendorName, DownalodChromeEvent, } from '../types'; interface AccountScrapingData { diff --git a/packages/renderer/src/store/Store.test.tsx b/packages/renderer/src/store/Store.test.tsx index 9ebe7a3a..335ae79a 100644 --- a/packages/renderer/src/store/Store.test.tsx +++ b/packages/renderer/src/store/Store.test.tsx @@ -1,25 +1,24 @@ -import { dummyConfig } from '../test/testData'; -import Store from './Store'; +import { configStore } from './ConfigStore'; import { AccountType, CompanyTypes, - type Config, + type Config, Credentials, type Exporter, type Importer, -} from './types'; +} from '../types'; +import { beforeEach, describe, test, expect } from 'vitest'; describe('Store', () => { - let store; + let store: any; beforeEach(() => { - store = new Store(); - store.configuration = dummyConfig; + store = configStore; + store.config = dummyConfig; }); describe('Properties and getters', () => { test('basic', () => { - const basicStore = new Store(); - expect(basicStore.config).not.toBeDefined(); + const basicStore = configStore; - basicStore.configuration = dummyConfig; + basicStore.config = dummyConfig; expect(basicStore.config).toMatchObject(dummyConfig); @@ -30,12 +29,12 @@ describe('Store', () => { expect(store.importers).toHaveLength(3); const discountImporter = store.importers.find( - (i) => i.companyId === 'discount', + (i: Importer) => i.companyId === 'discount', ); const visaCalImporter = store.importers.find( - (i) => i.companyId === 'visaCal', + (i: Importer) => i.companyId === 'visaCal', ); - const maxImporter = store.importers.find((i) => i.companyId === 'max'); + const maxImporter = store.importers.find((i: Importer) => i.companyId === 'max'); expect(discountImporter).toMatchSnapshot(); expect(visaCalImporter).toMatchSnapshot(); @@ -47,15 +46,6 @@ describe('Store', () => { expect(store.exporters).toMatchSnapshot(); }); - test('allAccounts', () => { - expect(store.allAccounts).toHaveLength( - store.importers.length + store.exporters.length, - ); - [...store.importers, ...store.exporters].forEach((account) => - expect(store.allAccounts).toContainEqual(account), - ); - }); - test('settings', () => { expect(store.settings.numDaysBack).toEqual( dummyConfig.scraping.numDaysBack, @@ -80,11 +70,9 @@ describe('Store', () => { type: AccountType.IMPORTER, active: false, }; - expect(store.allAccountsById.get(accountToAdd.id)).toBeFalsy(); const originalImportersLength = store.importers.length; store.addImporter(accountToAdd); expect(store.importers).toHaveLength(originalImportersLength + 1); - expect(store.allAccountsById.get(accountToAdd.id)).toMatchSnapshot(); }); test('updateImporter', () => { @@ -95,7 +83,7 @@ describe('Store', () => { }; store.updateImporter(importer.id, updatedImporter); expect( - store.importers.find((i) => i.id === importer.id), + store.importers.find((i: Importer) => i.id === importer.id), ).toHaveProperty('active', updatedImporter.active); }); @@ -104,10 +92,8 @@ describe('Store', () => { const originalNumImporters = dummyConfig.scraping.accountsToScrape.length; expect(store.importers).toHaveLength(originalNumImporters); - expect(store.allAccountsById.get(importer.id)).toBeTruthy(); store.deleteImporter(importer.id); expect(store.importers).toHaveLength(originalNumImporters - 1); - expect(store.allAccountsById.get(importer.id)).toBeFalsy(); }); }); describe('exporters', () => { @@ -133,7 +119,7 @@ export const dummyConfig: Config = { accountsToScrape: [ { active: true, - key: 'discount', + key: CompanyTypes.DISCOUNT, name: 'Discount Bank', loginFields: { id: '234234134', @@ -144,7 +130,7 @@ export const dummyConfig: Config = { }, { active: true, - key: 'visaCal', + key: CompanyTypes.VISACAL, name: 'Visa Cal', loginFields: { username: 'someUsername', @@ -154,7 +140,7 @@ export const dummyConfig: Config = { }, { active: true, - key: 'max', + key: CompanyTypes.MAX, name: 'Max', loginFields: { username: 'whatAUserName', @@ -163,6 +149,7 @@ export const dummyConfig: Config = { id: '9xve2485ac202f53f85bcdb4f795dssc', }, ], + timeout: 0, }, outputVendors: { csv: { @@ -193,8 +180,8 @@ export const dummyConfig: Config = { googleSheets: { active: false, options: { - credentials: '', spreadsheetId: '', + credentials: {} as Credentials, }, }, }, diff --git a/packages/renderer/src/store/__snapshots__/Store.test.tsx.snap b/packages/renderer/src/store/__snapshots__/Store.test.tsx.snap new file mode 100644 index 00000000..40f7ac9d --- /dev/null +++ b/packages/renderer/src/store/__snapshots__/Store.test.tsx.snap @@ -0,0 +1,125 @@ +// Vitest Snapshot v1, https://vitest.dev/guide/snapshot.html + +exports[`Store > Properties and getters > basic 1`] = ` +{ + "numDaysBack": 40, + "showBrowser": false, +} +`; + +exports[`Store > Properties and getters > exporters 1`] = ` +[ + { + "active": true, + "companyId": "csv", + "displayName": "אקסל", + "id": "csv", + "logo": "/src/assets/exporters/excel.png", + "logs": [], + "options": { + "filePath": "transaction.csv", + }, + "status": "idle", + "type": "Exporter", + }, + { + "active": false, + "companyId": "json", + "displayName": "Json", + "id": "json", + "logo": "/src/assets/exporters/json.jpeg", + "logs": [], + "options": { + "filePath": "transaction.json", + }, + "status": "idle", + "type": "Exporter", + }, + { + "active": true, + "companyId": "ynab", + "displayName": "Ynab", + "id": "ynab", + "logo": "/src/assets/exporters/ynab.jpeg", + "logs": [], + "options": { + "accessToken": "################-######-####-###", + "accountNumbersToYnabAccountIds": { + "1111": "xcvxcvxcvsd", + "3333": "xvxcdv", + "5555": "asdvasdvsdvs", + "555555555": "vsdvsdvserverv", + }, + "budgetId": "advasdvasd-asdvasdva-sdvasdvasdv-asdvasdvf", + }, + "status": "idle", + "type": "Exporter", + }, + { + "active": false, + "companyId": "googleSheets", + "displayName": "Google Sheets", + "id": "googleSheets", + "logo": "/src/assets/exporters/sheets.png", + "logs": [], + "options": { + "credentials": {}, + "spreadsheetId": "", + }, + "status": "idle", + "type": "Exporter", + }, +] +`; + +exports[`Store > Properties and getters > importers 1`] = ` +{ + "active": true, + "companyId": "discount", + "displayName": "דיסקונט", + "id": "efsvxasgd416f94d1e45a9cfc8c0a95f", + "loginFields": { + "id": "234234134", + "num": "LY9999", + "password": "notARealPass", + }, + "logo": "/src/assets/importers/discount.jpeg", + "logs": [], + "status": "idle", + "type": "Importer", +} +`; + +exports[`Store > Properties and getters > importers 2`] = ` +{ + "active": true, + "companyId": "visaCal", + "displayName": "ויזה כאל", + "id": "794a9ksj532d86cb4xxxb3438d0da942", + "loginFields": { + "password": "somePassword", + "username": "someUsername", + }, + "logo": "/src/assets/importers/visa-cal.jpeg", + "logs": [], + "status": "idle", + "type": "Importer", +} +`; + +exports[`Store > Properties and getters > importers 3`] = ` +{ + "active": true, + "companyId": "max", + "displayName": "Max", + "id": "9xve2485ac202f53f85bcdb4f795dssc", + "loginFields": { + "password": "greatPass", + "username": "whatAUserName", + }, + "logo": "/src/assets/importers/max.jpg", + "logs": [], + "status": "idle", + "type": "Importer", +} +`; diff --git a/packages/renderer/src/types.tsx b/packages/renderer/src/types.tsx index e719f551..a1406117 100644 --- a/packages/renderer/src/types.tsx +++ b/packages/renderer/src/types.tsx @@ -68,7 +68,6 @@ export interface JsonConfig extends OutputVendorConfigBase { export interface GoogleSheetsConfig extends OutputVendorConfigBase { options: { credentials: Auth.Credentials; - // credentials: string; spreadsheetId: string; }; } diff --git a/packages/renderer/tsconfig.json b/packages/renderer/tsconfig.json index e59d9bac..83f4c5d0 100644 --- a/packages/renderer/tsconfig.json +++ b/packages/renderer/tsconfig.json @@ -19,9 +19,7 @@ "lib": ["ESNext", "dom", "dom.iterable"] }, "include": [ - "src/**/*.vue", - "src/**/*.ts", - "src/**/*.tsx", + "src/**/*", "types/**/*.d.ts", "../../types/**/*.d.ts", "../../.eslintrc.cjs" diff --git a/packages/renderer/vitest-setup.js b/packages/renderer/vitest-setup.js new file mode 100644 index 00000000..edc677f1 --- /dev/null +++ b/packages/renderer/vitest-setup.js @@ -0,0 +1,29 @@ +import { vi } from 'vitest'; + +vi.mock('electron', () => ({ + default: { + ipcRenderer: { + invoke: vi.fn(), + send: vi.fn(), + }, + shell: { + openExternal: vi.fn(), + }, + }, +})); + +global.window.require = vi.fn().mockImplementation((module) => { + if (module === 'electron') { + return { + ipcRenderer: { + invoke: vi.fn(), + send: vi.fn(), + }, + shell: { + openExternal: vi.fn(), + }, + }; + } +}); + +import '@testing-library/jest-dom/vitest'; diff --git a/packages/renderer/vitest.config.js b/packages/renderer/vitest.config.js new file mode 100644 index 00000000..7a69b104 --- /dev/null +++ b/packages/renderer/vitest.config.js @@ -0,0 +1,19 @@ +import { defineConfig } from 'vitest/config'; +import tsconfigPaths from 'vite-tsconfig-paths'; +import baseConfig from '../../vitest.base.config.js'; +import path from 'path'; + +export default defineConfig({ + ...baseConfig, + plugins: [tsconfigPaths()], + resolve: { + alias: { + '@': path.resolve(__dirname, 'src'), + }, + extensions: ['.mjs', '.js', '.ts', '.tsx', '.json', '.jsx', '.css'], + }, + test: { + ...baseConfig.test, + setupFiles: path.resolve(__dirname, './vitest-setup.js'), + }, +}); diff --git a/vitest-setup.js b/vitest-setup.js index bb02c60c..225f2963 100644 --- a/vitest-setup.js +++ b/vitest-setup.js @@ -1 +1,26 @@ import '@testing-library/jest-dom/vitest'; +import { vi } from 'vitest'; + +vi.mock('electron', () => ({ + ipcRenderer: { + invoke: vi.fn(), + send: vi.fn(), + }, + shell: { + openExternal: vi.fn(), + }, +})); + +global.window.require = vi.fn().mockImplementation((module) => { + if (module === 'electron') { + return { + ipcRenderer: { + invoke: vi.fn(), + send: vi.fn(), + }, + shell: { + openExternal: vi.fn(), + }, + }; + } +}); diff --git a/vitest.base.config.js b/vitest.base.config.js new file mode 100644 index 00000000..f04414cb --- /dev/null +++ b/vitest.base.config.js @@ -0,0 +1,7 @@ +export default { + test: { + environment: 'jsdom', + testTimeout: 30_000, + hookTimeout: 30_000, + }, +}; \ No newline at end of file diff --git a/vitest.config.js b/vitest.config.js index f78a20c6..e2c8a90a 100644 --- a/vitest.config.js +++ b/vitest.config.js @@ -1,12 +1,15 @@ import { svelte } from '@sveltejs/vite-plugin-svelte'; import { svelteTesting } from '@testing-library/svelte/vite'; import { defineConfig } from 'vitest/config'; +import tsconfigPaths from 'vite-tsconfig-paths'; +import baseConfig from 'vitest.base.config.js'; export default defineConfig({ - plugins: [svelte(), svelteTesting()], + ...baseConfig, + plugins: [svelte(), svelteTesting(), tsconfigPaths()], test: { environment: 'jsdom', - setupFiles: ['./vitest-setup.js'], + setupFiles: './vitest-setup.js', /** * By default, vitest searches for the test files in all packages. * For e2e tests, have vitest search only in the project root 'tests' folder. diff --git a/yarn.lock b/yarn.lock index 38da1869..4826cb11 100644 --- a/yarn.lock +++ b/yarn.lock @@ -12,7 +12,7 @@ resolved "https://registry.yarnpkg.com/@adobe/css-tools/-/css-tools-4.4.0.tgz#728c484f4e10df03d5a3acd0d8adcbbebff8ad63" integrity sha512-Ff9+ksdQQB3rMncgqDK78uLznstjyfIf2Arnh22pW8kBpLs6rpKDwgnZT46hin5Hl1WzazzK64DOrhSwYpS7bQ== -"@ampproject/remapping@^2.2.0", "@ampproject/remapping@^2.3.0": +"@ampproject/remapping@^2.2.0", "@ampproject/remapping@^2.2.1": version "2.3.0" resolved "https://registry.yarnpkg.com/@ampproject/remapping/-/remapping-2.3.0.tgz#ed441b6fa600072520ce18b43d2c8cc8caecc7f4" integrity sha512-30iZtAPgz+LTIYoeivqYo853f02jBYSd5uGnGpkFV0M3xOt9aN73erkgYAmZU43x4VfqcnLxW9Kpg3R5LC4YYw== @@ -547,11 +547,16 @@ dependencies: eslint-visitor-keys "^3.3.0" -"@eslint-community/regexpp@^4.10.0", "@eslint-community/regexpp@^4.6.1": +"@eslint-community/regexpp@^4.10.0": version "4.10.1" resolved "https://registry.yarnpkg.com/@eslint-community/regexpp/-/regexpp-4.10.1.tgz#361461e5cb3845d874e61731c11cfedd664d83a0" integrity sha512-Zm2NGpWELsQAD1xsJzGQpYfvICSsFkEpU0jxBjfdC6uNEWXcHnfs9hScFWtXVDVl+rBQJGrl4g1vcKIejpH9dA== +"@eslint-community/regexpp@^4.6.1": + version "4.11.1" + resolved "https://registry.yarnpkg.com/@eslint-community/regexpp/-/regexpp-4.11.1.tgz#a547badfc719eb3e5f4b556325e542fbe9d7a18f" + integrity sha512-m4DVN9ZqskZoLU5GlWZadwDnYo3vAEydiUayB9widCl9ffWx2IvPnp6n3on5rJmziJSw9Bv+Z3ChDVdMwXCY8Q== + "@eslint/eslintrc@^2.1.4": version "2.1.4" resolved "https://registry.yarnpkg.com/@eslint/eslintrc/-/eslintrc-2.1.4.tgz#388a269f0f25c1b6adc317b5a2c55714894c70ad" @@ -632,7 +637,7 @@ resolved "https://registry.yarnpkg.com/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.5.0.tgz#3188bcb273a414b0d215fd22a58540b989b9409a" integrity sha512-gv3ZRaISU3fjPAgNsriBRqGWQL6quFx04YMPW/zD8XMLsU32mhCCbfbO6KZFLjvYpCZ8zyDEgqsgf+PwPaM7GQ== -"@jridgewell/trace-mapping@^0.3.24", "@jridgewell/trace-mapping@^0.3.25": +"@jridgewell/trace-mapping@^0.3.18", "@jridgewell/trace-mapping@^0.3.24", "@jridgewell/trace-mapping@^0.3.25": version "0.3.25" resolved "https://registry.yarnpkg.com/@jridgewell/trace-mapping/-/trace-mapping-0.3.25.tgz#15f190e98895f3fc23276ee14bc76b675c2e50f0" integrity sha512-vNk6aEwybGtawWmy/PzwnGDOjCkLWSD2wqvjGGAgOAwCGWySYXfYoxt00IJkTF+8Lb57DwOb3Aa0o9CApepiYQ== @@ -1007,7 +1012,16 @@ uncontrollable "^8.0.1" warning "^4.0.3" -"@rollup/pluginutils@^5.1.0": +"@rollup/plugin-inject@^5.0.5": + version "5.0.5" + resolved "https://registry.yarnpkg.com/@rollup/plugin-inject/-/plugin-inject-5.0.5.tgz#616f3a73fe075765f91c5bec90176608bed277a3" + integrity sha512-2+DEJbNBoPROPkgTDNe8/1YXWcqxbN5DTjASVIOx8HS+pITXushyNiBV56RB08zuptzz8gT3YfkqriTBVycepg== + dependencies: + "@rollup/pluginutils" "^5.0.1" + estree-walker "^2.0.2" + magic-string "^0.30.3" + +"@rollup/pluginutils@^5.0.1", "@rollup/pluginutils@^5.1.0": version "5.1.0" resolved "https://registry.yarnpkg.com/@rollup/pluginutils/-/pluginutils-5.1.0.tgz#7e53eddc8c7f483a4ad0b94afb1f7f5fd3c771e0" integrity sha512-XTIWOPPcpvyKI6L1NHo0lFlCyznUEyPmPY1mc3KpPVDYulHSTvyeLNVW00QTLIAFNhR3kYnJTQHeGqU4M3n09g== @@ -1439,6 +1453,11 @@ dependencies: "@types/ms" "*" +"@types/estree@*", "@types/estree@^1.0.1": + version "1.0.6" + resolved "https://registry.yarnpkg.com/@types/estree/-/estree-1.0.6.tgz#628effeeae2064a1b4e79f78e81d87b7e5fc7b50" + integrity sha512-AYnb1nQyY49te+VRAVgmzfcgjYS91mY5P0TKUDCLEM+gNnA+3T6rWITXRLYCpahpqSQbN5cE+gHpnPyXjHWxcw== + "@types/estree@1.0.5", "@types/estree@^1.0.0": version "1.0.5" resolved "https://registry.yarnpkg.com/@types/estree/-/estree-1.0.5.tgz#a6ce3e556e00fd9895dd872dd172ad0d4bd687f4" @@ -1711,14 +1730,14 @@ ts-api-utils "^1.3.0" "@typescript-eslint/parser@^7.12.0": - version "7.12.0" - resolved "https://registry.yarnpkg.com/@typescript-eslint/parser/-/parser-7.12.0.tgz#8761df3345528b35049353db80010b385719b1c3" - integrity sha512-dm/J2UDY3oV3TKius2OUZIFHsomQmpHtsV0FTh1WO8EKgHLQ1QCADUqscPgTpU+ih1e21FQSRjXckHn3txn6kQ== - dependencies: - "@typescript-eslint/scope-manager" "7.12.0" - "@typescript-eslint/types" "7.12.0" - "@typescript-eslint/typescript-estree" "7.12.0" - "@typescript-eslint/visitor-keys" "7.12.0" + version "7.18.0" + resolved "https://registry.yarnpkg.com/@typescript-eslint/parser/-/parser-7.18.0.tgz#83928d0f1b7f4afa974098c64b5ce6f9051f96a0" + integrity sha512-4Z+L8I2OqhZV8qA132M4wNL30ypZGYOQVBfMgxDH/K5UX0PNqTu1c6za9ST5r9+tavvHiTWmBnKzpCJ/GlVFtg== + dependencies: + "@typescript-eslint/scope-manager" "7.18.0" + "@typescript-eslint/types" "7.18.0" + "@typescript-eslint/typescript-estree" "7.18.0" + "@typescript-eslint/visitor-keys" "7.18.0" debug "^4.3.4" "@typescript-eslint/scope-manager@7.12.0": @@ -1729,6 +1748,14 @@ "@typescript-eslint/types" "7.12.0" "@typescript-eslint/visitor-keys" "7.12.0" +"@typescript-eslint/scope-manager@7.18.0": + version "7.18.0" + resolved "https://registry.yarnpkg.com/@typescript-eslint/scope-manager/-/scope-manager-7.18.0.tgz#c928e7a9fc2c0b3ed92ab3112c614d6bd9951c83" + integrity sha512-jjhdIE/FPF2B7Z1uzc6i3oWKbGcHb87Qw7AWj6jmEqNOfDFbJWtjt/XfwCpvNkpGWlcJaog5vTR+VV8+w9JflA== + dependencies: + "@typescript-eslint/types" "7.18.0" + "@typescript-eslint/visitor-keys" "7.18.0" + "@typescript-eslint/type-utils@7.12.0": version "7.12.0" resolved "https://registry.yarnpkg.com/@typescript-eslint/type-utils/-/type-utils-7.12.0.tgz#9dfaaa1972952f395ec5be4f5bbfc4d3cdc63908" @@ -1744,6 +1771,11 @@ resolved "https://registry.yarnpkg.com/@typescript-eslint/types/-/types-7.12.0.tgz#bf208f971a8da1e7524a5d9ae2b5f15192a37981" integrity sha512-o+0Te6eWp2ppKY3mLCU+YA9pVJxhUJE15FV7kxuD9jgwIAa+w/ycGJBMrYDTpVGUM/tgpa9SeMOugSabWFq7bg== +"@typescript-eslint/types@7.18.0": + version "7.18.0" + resolved "https://registry.yarnpkg.com/@typescript-eslint/types/-/types-7.18.0.tgz#b90a57ccdea71797ffffa0321e744f379ec838c9" + integrity sha512-iZqi+Ds1y4EDYUtlOOC+aUmxnE9xS/yCigkjA7XpTKV6nCBd3Hp/PRGGmdwnfkV2ThMyYldP1wRpm/id99spTQ== + "@typescript-eslint/typescript-estree@7.12.0": version "7.12.0" resolved "https://registry.yarnpkg.com/@typescript-eslint/typescript-estree/-/typescript-estree-7.12.0.tgz#e6c1074f248b3db6573ab6a7c47a39c4cd498ff9" @@ -1758,6 +1790,20 @@ semver "^7.6.0" ts-api-utils "^1.3.0" +"@typescript-eslint/typescript-estree@7.18.0": + version "7.18.0" + resolved "https://registry.yarnpkg.com/@typescript-eslint/typescript-estree/-/typescript-estree-7.18.0.tgz#b5868d486c51ce8f312309ba79bdb9f331b37931" + integrity sha512-aP1v/BSPnnyhMHts8cf1qQ6Q1IFwwRvAQGRvBFkWlo3/lH29OXA3Pts+c10nxRxIBrDnoMqzhgdwVe5f2D6OzA== + dependencies: + "@typescript-eslint/types" "7.18.0" + "@typescript-eslint/visitor-keys" "7.18.0" + debug "^4.3.4" + globby "^11.1.0" + is-glob "^4.0.3" + minimatch "^9.0.4" + semver "^7.6.0" + ts-api-utils "^1.3.0" + "@typescript-eslint/utils@7.12.0": version "7.12.0" resolved "https://registry.yarnpkg.com/@typescript-eslint/utils/-/utils-7.12.0.tgz#c6e58fd7f724cdccc848f71e388ad80cbdb95dd0" @@ -1776,6 +1822,14 @@ "@typescript-eslint/types" "7.12.0" eslint-visitor-keys "^3.4.3" +"@typescript-eslint/visitor-keys@7.18.0": + version "7.18.0" + resolved "https://registry.yarnpkg.com/@typescript-eslint/visitor-keys/-/visitor-keys-7.18.0.tgz#0564629b6124d67607378d0f0332a0495b25e7d7" + integrity sha512-cDF0/Gf81QpY3xYyJKDV14Zwdmid5+uuENhjH2EqFaF0ni+yAyq/LzMaIJdhNJXZI7uLzwIlA+V7oWoyn6Curg== + dependencies: + "@typescript-eslint/types" "7.18.0" + eslint-visitor-keys "^3.4.3" + "@ungap/structured-clone@^1.2.0": version "1.2.0" resolved "https://registry.yarnpkg.com/@ungap/structured-clone/-/structured-clone-1.2.0.tgz#756641adb587851b5ccb3e095daf27ae581c8406" @@ -1792,54 +1846,62 @@ "@types/babel__core" "^7.20.5" react-refresh "^0.14.2" -"@vitest/expect@2.0.5": - version "2.0.5" - resolved "https://registry.yarnpkg.com/@vitest/expect/-/expect-2.0.5.tgz#f3745a6a2c18acbea4d39f5935e913f40d26fa86" - integrity sha512-yHZtwuP7JZivj65Gxoi8upUN2OzHTi3zVfjwdpu2WrvCZPLwsJ2Ey5ILIPccoW23dd/zQBlJ4/dhi7DWNyXCpA== +"@vitest/expect@2.1.1": + version "2.1.1" + resolved "https://registry.yarnpkg.com/@vitest/expect/-/expect-2.1.1.tgz#907137a86246c5328929d796d741c4e95d1ee19d" + integrity sha512-YeueunS0HiHiQxk+KEOnq/QMzlUuOzbU1Go+PgAsHvvv3tUkJPm9xWt+6ITNTlzsMXUjmgm5T+U7KBPK2qQV6w== dependencies: - "@vitest/spy" "2.0.5" - "@vitest/utils" "2.0.5" + "@vitest/spy" "2.1.1" + "@vitest/utils" "2.1.1" chai "^5.1.1" tinyrainbow "^1.2.0" -"@vitest/pretty-format@2.0.5", "@vitest/pretty-format@^2.0.5": - version "2.0.5" - resolved "https://registry.yarnpkg.com/@vitest/pretty-format/-/pretty-format-2.0.5.tgz#91d2e6d3a7235c742e1a6cc50e7786e2f2979b1e" - integrity sha512-h8k+1oWHfwTkyTkb9egzwNMfJAEx4veaPSnMeKbVSjp4euqGSbQlm5+6VHwTr7u4FJslVVsUG5nopCaAYdOmSQ== +"@vitest/mocker@2.1.1": + version "2.1.1" + resolved "https://registry.yarnpkg.com/@vitest/mocker/-/mocker-2.1.1.tgz#3e37c80ac267318d4aa03c5073a017d148dc8e67" + integrity sha512-LNN5VwOEdJqCmJ/2XJBywB11DLlkbY0ooDJW3uRX5cZyYCrc4PI/ePX0iQhE3BiEGiQmK4GE7Q/PqCkkaiPnrA== + dependencies: + "@vitest/spy" "^2.1.0-beta.1" + estree-walker "^3.0.3" + magic-string "^0.30.11" + +"@vitest/pretty-format@2.1.1", "@vitest/pretty-format@^2.1.1": + version "2.1.1" + resolved "https://registry.yarnpkg.com/@vitest/pretty-format/-/pretty-format-2.1.1.tgz#fea25dd4e88c3c1329fbccd1d16b1d607eb40067" + integrity sha512-SjxPFOtuINDUW8/UkElJYQSFtnWX7tMksSGW0vfjxMneFqxVr8YJ979QpMbDW7g+BIiq88RAGDjf7en6rvLPPQ== dependencies: tinyrainbow "^1.2.0" -"@vitest/runner@2.0.5": - version "2.0.5" - resolved "https://registry.yarnpkg.com/@vitest/runner/-/runner-2.0.5.tgz#89197e712bb93513537d6876995a4843392b2a84" - integrity sha512-TfRfZa6Bkk9ky4tW0z20WKXFEwwvWhRY+84CnSEtq4+3ZvDlJyY32oNTJtM7AW9ihW90tX/1Q78cb6FjoAs+ig== +"@vitest/runner@2.1.1": + version "2.1.1" + resolved "https://registry.yarnpkg.com/@vitest/runner/-/runner-2.1.1.tgz#f3b1fbc3c109fc44e2cceecc881344453f275559" + integrity sha512-uTPuY6PWOYitIkLPidaY5L3t0JJITdGTSwBtwMjKzo5O6RCOEncz9PUN+0pDidX8kTHYjO0EwUIvhlGpnGpxmA== dependencies: - "@vitest/utils" "2.0.5" + "@vitest/utils" "2.1.1" pathe "^1.1.2" -"@vitest/snapshot@2.0.5": - version "2.0.5" - resolved "https://registry.yarnpkg.com/@vitest/snapshot/-/snapshot-2.0.5.tgz#a2346bc5013b73c44670c277c430e0334690a162" - integrity sha512-SgCPUeDFLaM0mIUHfaArq8fD2WbaXG/zVXjRupthYfYGzc8ztbFbu6dUNOblBG7XLMR1kEhS/DNnfCZ2IhdDew== +"@vitest/snapshot@2.1.1": + version "2.1.1" + resolved "https://registry.yarnpkg.com/@vitest/snapshot/-/snapshot-2.1.1.tgz#38ef23104e90231fea5540754a19d8468afbba66" + integrity sha512-BnSku1WFy7r4mm96ha2FzN99AZJgpZOWrAhtQfoxjUU5YMRpq1zmHRq7a5K9/NjqonebO7iVDla+VvZS8BOWMw== dependencies: - "@vitest/pretty-format" "2.0.5" - magic-string "^0.30.10" + "@vitest/pretty-format" "2.1.1" + magic-string "^0.30.11" pathe "^1.1.2" -"@vitest/spy@2.0.5": - version "2.0.5" - resolved "https://registry.yarnpkg.com/@vitest/spy/-/spy-2.0.5.tgz#590fc07df84a78b8e9dd976ec2090920084a2b9f" - integrity sha512-c/jdthAhvJdpfVuaexSrnawxZz6pywlTPe84LUB2m/4t3rl2fTo9NFGBG4oWgaD+FTgDDV8hJ/nibT7IfH3JfA== +"@vitest/spy@2.1.1", "@vitest/spy@^2.1.0-beta.1": + version "2.1.1" + resolved "https://registry.yarnpkg.com/@vitest/spy/-/spy-2.1.1.tgz#20891f7421a994256ea0d739ed72f05532c78488" + integrity sha512-ZM39BnZ9t/xZ/nF4UwRH5il0Sw93QnZXd9NAZGRpIgj0yvVwPpLd702s/Cx955rGaMlyBQkZJ2Ir7qyY48VZ+g== dependencies: tinyspy "^3.0.0" -"@vitest/utils@2.0.5": - version "2.0.5" - resolved "https://registry.yarnpkg.com/@vitest/utils/-/utils-2.0.5.tgz#6f8307a4b6bc6ceb9270007f73c67c915944e926" - integrity sha512-d8HKbqIcya+GR67mkZbrzhS5kKhtp8dQLcmRZLGTscGVg7yImT82cIrhtn2L8+VujWcy6KZweApgNmPsTAO/UQ== +"@vitest/utils@2.1.1": + version "2.1.1" + resolved "https://registry.yarnpkg.com/@vitest/utils/-/utils-2.1.1.tgz#284d016449ecb4f8704d198d049fde8360cc136e" + integrity sha512-Y6Q9TsI+qJ2CC0ZKj6VBb+T8UPz593N113nnUykqwANqhgf3QkZeHFlusgKLTqrnVHbj/XDKZcDHol+dxVT+rQ== dependencies: - "@vitest/pretty-format" "2.0.5" - estree-walker "^3.0.3" + "@vitest/pretty-format" "2.1.1" loupe "^3.1.1" tinyrainbow "^1.2.0" @@ -2008,6 +2070,11 @@ aria-query@5.3.0, aria-query@^5.0.0: dependencies: dequal "^2.0.3" +aria-query@^5.3.0: + version "5.3.2" + resolved "https://registry.yarnpkg.com/aria-query/-/aria-query-5.3.2.tgz#93f81a43480e33a338f19163a3d10a50c01dcd59" + integrity sha512-COROpnaoap1E2F000S62r6A60uHZnmlvomhfyT2DlTcrY1OrBKn2UhH7qn5wTC9zMvD0AY7csdPSNwKP+7WiQw== + array-ify@^1.0.0: version "1.0.0" resolved "https://registry.yarnpkg.com/array-ify/-/array-ify-1.0.0.tgz#9e528762b4a9066ad163a6962a364418e9626ece" @@ -2023,11 +2090,31 @@ arrify@^2.0.0: resolved "https://registry.yarnpkg.com/arrify/-/arrify-2.0.1.tgz#c9655e9331e0abcd588d2a7cad7e9956f66701fa" integrity sha512-3duEwti880xqi4eAMN8AyR4a0ByT90zoYdLlevfrvU43vb0YZwZVfxOgxWrLXXXpyugL0hNZc9G6BiB5B3nUug== +asn1.js@^4.10.1: + version "4.10.1" + resolved "https://registry.yarnpkg.com/asn1.js/-/asn1.js-4.10.1.tgz#b9c2bf5805f1e64aadeed6df3a2bfafb5a73f5a0" + integrity sha512-p32cOF5q0Zqs9uBiONKYLm6BClCoBCM5O9JfeUSlnQLBTxYdTK+pW+nXflm8UkKd2UYlEbYz5qEi0JuZR9ckSw== + dependencies: + bn.js "^4.0.0" + inherits "^2.0.1" + minimalistic-assert "^1.0.0" + assert-plus@^1.0.0: version "1.0.0" resolved "https://registry.yarnpkg.com/assert-plus/-/assert-plus-1.0.0.tgz#f12e0f3c5d77b0b1cdd9146942e4e96c1e4dd525" integrity sha512-NfJ4UzBCcQGLDlQq7nHxH+tv3kyZ0hHQqF5BO6J7tNJeP5do1llPr8dZ8zHonfhAu0PHAdMkSo+8o0wxg9lZWw== +assert@^2.0.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/assert/-/assert-2.1.0.tgz#6d92a238d05dc02e7427c881fb8be81c8448b2dd" + integrity sha512-eLHpSK/Y4nhMJ07gDaAzoX/XAKS8PSaojml3M0DM4JpV1LAi5JOJ/p6H/XWrl8L+DzVEvVCW1z3vWAaB9oTsQw== + dependencies: + call-bind "^1.0.2" + is-nan "^1.3.2" + object-is "^1.1.5" + object.assign "^4.1.4" + util "^0.12.5" + assertion-error@^2.0.1: version "2.0.1" resolved "https://registry.yarnpkg.com/assertion-error/-/assertion-error-2.0.1.tgz#f641a196b335690b1070bf00b6e7593fec190bf7" @@ -2065,6 +2152,13 @@ at-least-node@^1.0.0: resolved "https://registry.yarnpkg.com/at-least-node/-/at-least-node-1.0.0.tgz#602cd4b46e844ad4effc92a8011a3c46e0238dc2" integrity sha512-+q/t7Ekv1EDY2l6Gda6LLiX14rU9TV20Wa3ofeQmwPFZbOMo9DXrLbOjFaaclkXKWidIaopwAObQDqwWtGUjqg== +available-typed-arrays@^1.0.7: + version "1.0.7" + resolved "https://registry.yarnpkg.com/available-typed-arrays/-/available-typed-arrays-1.0.7.tgz#a5cc375d6a03c2efc87a553f3e0b1522def14846" + integrity sha512-wvUjBtSGN7+7SjNpq/9M2Tg350UZD3q62IFZLbRAR1bSMlCo1ZaeW+BJ+D090e4hIIZLBcTDWe4Mh4jvUDajzQ== + dependencies: + possible-typed-array-names "^1.0.0" + axios-retry@3.2.0: version "3.2.0" resolved "https://registry.yarnpkg.com/axios-retry/-/axios-retry-3.2.0.tgz#eb48e72f90b177fde62329b2896aa8476cfb90ba" @@ -2080,6 +2174,11 @@ axios@^0.27.2: follow-redirects "^1.14.9" form-data "^4.0.0" +axobject-query@^4.0.0: + version "4.1.0" + resolved "https://registry.yarnpkg.com/axobject-query/-/axobject-query-4.1.0.tgz#28768c76d0e3cff21bc62a9e2d0b6ac30042a1ee" + integrity sha512-qIj0G9wZbMGNLjLmg1PT6v2mE9AH2zlnADJD/2tC6E00hgmhUOfEB6greHPAfLRSufHqROIUTkw6E+M3lH0PTQ== + b4a@^1.6.4: version "1.6.6" resolved "https://registry.yarnpkg.com/b4a/-/b4a-1.6.6.tgz#a4cc349a3851987c3c4ac2d7785c18744f6da9ba" @@ -2164,6 +2263,16 @@ bluebird@^3.5.5: resolved "https://registry.yarnpkg.com/bluebird/-/bluebird-3.7.2.tgz#9f229c15be272454ffa973ace0dbee79a1b0c36f" integrity sha512-XpNj6GDQzdfW+r2Wnn7xiSAd7TM3jzkxGXBGTtWKuSXv1xUV+azxAm8jdWZN06QTQk+2N2XB9jRDkvbmQmcRtg== +bn.js@^4.0.0, bn.js@^4.1.0, bn.js@^4.11.9: + version "4.12.0" + resolved "https://registry.yarnpkg.com/bn.js/-/bn.js-4.12.0.tgz#775b3f278efbb9718eec7361f483fb36fbbfea88" + integrity sha512-c98Bf3tPniI+scsdk237ku1Dc3ujXQTSgyiPUDEOe7tRkhrqridvh8klBv0HCEso1OLOYcHuCv/cS6DNxKH+ZA== + +bn.js@^5.0.0, bn.js@^5.2.1: + version "5.2.1" + resolved "https://registry.yarnpkg.com/bn.js/-/bn.js-5.2.1.tgz#0bc527a6a0d18d0aa8d5b0538ce4a77dccfa7b70" + integrity sha512-eXRvHzWyYPBuB4NBy0cmYQjGitUrtqwbvlzP3G6VFnNRbsZQIxQ10PbKKHt8gZ/HW/D/747aDl+QkDqg3KQLMQ== + boolean@^3.0.1: version "3.2.0" resolved "https://registry.yarnpkg.com/boolean/-/boolean-3.2.0.tgz#9e5294af4e98314494cbb17979fa54ca159f116b" @@ -2201,6 +2310,80 @@ braces@^3.0.3, braces@~3.0.2: dependencies: fill-range "^7.1.1" +brorand@^1.0.1, brorand@^1.1.0: + version "1.1.0" + resolved "https://registry.yarnpkg.com/brorand/-/brorand-1.1.0.tgz#12c25efe40a45e3c323eb8675a0a0ce57b22371f" + integrity sha512-cKV8tMCEpQs4hK/ik71d6LrPOnpkpGBR0wzxqr68g2m/LB2GxVYQroAjMJZRVM1Y4BCjCKc3vAamxSzOY2RP+w== + +browser-resolve@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/browser-resolve/-/browser-resolve-2.0.0.tgz#99b7304cb392f8d73dba741bb2d7da28c6d7842b" + integrity sha512-7sWsQlYL2rGLy2IWm8WL8DCTJvYLc/qlOnsakDac87SOoCd16WLsaAMdCiAqsTNHIe+SXfaqyxyo6THoWqs8WQ== + dependencies: + resolve "^1.17.0" + +browserify-aes@^1.0.4, browserify-aes@^1.2.0: + version "1.2.0" + resolved "https://registry.yarnpkg.com/browserify-aes/-/browserify-aes-1.2.0.tgz#326734642f403dabc3003209853bb70ad428ef48" + integrity sha512-+7CHXqGuspUn/Sl5aO7Ea0xWGAtETPXNSAjHo48JfLdPWcMng33Xe4znFvQweqc/uzk5zSOI3H52CYnjCfb5hA== + dependencies: + buffer-xor "^1.0.3" + cipher-base "^1.0.0" + create-hash "^1.1.0" + evp_bytestokey "^1.0.3" + inherits "^2.0.1" + safe-buffer "^5.0.1" + +browserify-cipher@^1.0.0: + version "1.0.1" + resolved "https://registry.yarnpkg.com/browserify-cipher/-/browserify-cipher-1.0.1.tgz#8d6474c1b870bfdabcd3bcfcc1934a10e94f15f0" + integrity sha512-sPhkz0ARKbf4rRQt2hTpAHqn47X3llLkUGn+xEJzLjwY8LRs2p0v7ljvI5EyoRO/mexrNunNECisZs+gw2zz1w== + dependencies: + browserify-aes "^1.0.4" + browserify-des "^1.0.0" + evp_bytestokey "^1.0.0" + +browserify-des@^1.0.0: + version "1.0.2" + resolved "https://registry.yarnpkg.com/browserify-des/-/browserify-des-1.0.2.tgz#3af4f1f59839403572f1c66204375f7a7f703e9c" + integrity sha512-BioO1xf3hFwz4kc6iBhI3ieDFompMhrMlnDFC4/0/vd5MokpuAc3R+LYbwTA9A5Yc9pq9UYPqffKpW2ObuwX5A== + dependencies: + cipher-base "^1.0.1" + des.js "^1.0.0" + inherits "^2.0.1" + safe-buffer "^5.1.2" + +browserify-rsa@^4.0.0, browserify-rsa@^4.1.0: + version "4.1.0" + resolved "https://registry.yarnpkg.com/browserify-rsa/-/browserify-rsa-4.1.0.tgz#b2fd06b5b75ae297f7ce2dc651f918f5be158c8d" + integrity sha512-AdEER0Hkspgno2aR97SAf6vi0y0k8NuOpGnVH3O99rcA5Q6sh8QxcngtHuJ6uXwnfAXNM4Gn1Gb7/MV1+Ymbog== + dependencies: + bn.js "^5.0.0" + randombytes "^2.0.1" + +browserify-sign@^4.0.0: + version "4.2.3" + resolved "https://registry.yarnpkg.com/browserify-sign/-/browserify-sign-4.2.3.tgz#7afe4c01ec7ee59a89a558a4b75bd85ae62d4208" + integrity sha512-JWCZW6SKhfhjJxO8Tyiiy+XYB7cqd2S5/+WeYHsKdNKFlCBhKbblba1A/HN/90YwtxKc8tCErjffZl++UNmGiw== + dependencies: + bn.js "^5.2.1" + browserify-rsa "^4.1.0" + create-hash "^1.2.0" + create-hmac "^1.1.7" + elliptic "^6.5.5" + hash-base "~3.0" + inherits "^2.0.4" + parse-asn1 "^5.1.7" + readable-stream "^2.3.8" + safe-buffer "^5.2.1" + +browserify-zlib@^0.2.0: + version "0.2.0" + resolved "https://registry.yarnpkg.com/browserify-zlib/-/browserify-zlib-0.2.0.tgz#2869459d9aa3be245fe8fe2ca1f46e2e7f54d73f" + integrity sha512-Z942RysHXmJrhqk88FmKBVq/v5tqmSkDz7p54G/MGyjMnCFFnC79XWNbg+Vta8W6Wb2qtSZTSxIGkJrRpCFEiA== + dependencies: + pako "~1.0.5" + browserslist@^4.22.2: version "4.23.1" resolved "https://registry.yarnpkg.com/browserslist/-/browserslist-4.23.1.tgz#ce4af0534b3d37db5c1a4ca98b9080f985041e96" @@ -2231,7 +2414,12 @@ buffer-from@^1.0.0: resolved "https://registry.yarnpkg.com/buffer-from/-/buffer-from-1.1.2.tgz#2b146a6fd72e80b4f55d255f35ed59a3a9a41bd5" integrity sha512-E+XQCRwSbaaiChtv6k6Dwgc+bx+Bs6vuKJHHl5kox/BaKbhiXzqQOwK4cO22yElGp2OCmjwVhT3HmxgyPGnJfQ== -buffer@^5.1.0, buffer@^5.2.1, buffer@^5.5.0: +buffer-xor@^1.0.3: + version "1.0.3" + resolved "https://registry.yarnpkg.com/buffer-xor/-/buffer-xor-1.0.3.tgz#26e61ed1422fb70dd42e6e36729ed51d855fe8d9" + integrity sha512-571s0T7nZWK6vB67HI5dyUF7wXiNcfaPPPTl6zYCNApANjIvYJTg7hlud/+cJpdAhS7dVzqMLmfhfHR3rAcOjQ== + +buffer@^5.1.0, buffer@^5.2.1, buffer@^5.5.0, buffer@^5.7.1: version "5.7.1" resolved "https://registry.yarnpkg.com/buffer/-/buffer-5.7.1.tgz#ba62e7c13133053582197160851a8f648e99eed0" integrity sha512-EHcyIPBQ4BSGlvjB16k5KgAJ27CIsHY/2JBmCRReo48y9rQ3MaUzWX3KVlBa4U7MyX02HdVj0K7C3WaB3ju7FQ== @@ -2282,6 +2470,11 @@ builder-util@24.13.1: stat-mode "^1.0.0" temp-file "^3.4.0" +builtin-status-codes@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/builtin-status-codes/-/builtin-status-codes-3.0.0.tgz#85982878e21b98e1c66425e03d0174788f569ee8" + integrity sha512-HpGFw18DgFWlncDfjTa2rcQ4W88O1mC8e8yZ2AvQY5KDaktSTwo+KRf6nHK6FRI5FyRyb/5T6+TSxfP7QyGsmQ== + cac@^6.7.14: version "6.7.14" resolved "https://registry.yarnpkg.com/cac/-/cac-6.7.14.tgz#804e1e6f506ee363cb0e3ccbb09cad5dd9870959" @@ -2305,7 +2498,7 @@ cacheable-request@^7.0.2: normalize-url "^6.0.1" responselike "^2.0.0" -call-bind@^1.0.7: +call-bind@^1.0.0, call-bind@^1.0.2, call-bind@^1.0.5, call-bind@^1.0.7: version "1.0.7" resolved "https://registry.yarnpkg.com/call-bind/-/call-bind-1.0.7.tgz#06016599c40c56498c18769d2730be242b6fa3b9" integrity sha512-GHTSNSYICQ7scH7sZ+M2rFopRoLh8t2bLSW6BbgrtLsahOIB5iyAVJf9GjWK3cYTDaMj4XdBpM1cA6pIS0Kv2w== @@ -2425,6 +2618,14 @@ ci-info@^3.2.0: resolved "https://registry.yarnpkg.com/ci-info/-/ci-info-3.9.0.tgz#4279a62028a7b1f262f3473fc9605f5e218c59b4" integrity sha512-NIxF55hv4nSqQswkAeiOi1r83xy8JldOFDTWiug55KBu9Jnblncd2U6ViHmYgHf01TPZS77NJBhBMKdWj9HQMQ== +cipher-base@^1.0.0, cipher-base@^1.0.1, cipher-base@^1.0.3: + version "1.0.4" + resolved "https://registry.yarnpkg.com/cipher-base/-/cipher-base-1.0.4.tgz#8760e4ecc272f4c363532f926d874aae2c1397de" + integrity sha512-Kkht5ye6ZGmwv40uUDZztayT2ThLQGfnj/T71N/XzeZeo3nf8foyW7zGTsPYkEya3m5f3cAypH+qe7YOrM1U2Q== + dependencies: + inherits "^2.0.1" + safe-buffer "^5.0.1" + cjs-module-lexer@^1.2.2: version "1.3.1" resolved "https://registry.yarnpkg.com/cjs-module-lexer/-/cjs-module-lexer-1.3.1.tgz#c485341ae8fd999ca4ee5af2d7a1c9ae01e0099c" @@ -2459,6 +2660,17 @@ clone-response@^1.0.2: dependencies: mimic-response "^1.0.0" +code-red@^1.0.3: + version "1.0.4" + resolved "https://registry.yarnpkg.com/code-red/-/code-red-1.0.4.tgz#59ba5c9d1d320a4ef795bc10a28bd42bfebe3e35" + integrity sha512-7qJWqItLA8/VPVlKJlFXU+NBlo/qyfs39aJcuMT/2ere32ZqvF5OSxgdM5xOfJJ7O429gg2HM47y8v9P+9wrNw== + dependencies: + "@jridgewell/sourcemap-codec" "^1.4.15" + "@types/estree" "^1.0.1" + acorn "^8.10.0" + estree-walker "^3.0.3" + periscopic "^3.1.0" + color-convert@^1.9.0: version "1.9.3" resolved "https://registry.yarnpkg.com/color-convert/-/color-convert-1.9.3.tgz#bb71850690e1f136567de629d2d5471deda4c1e8" @@ -2541,6 +2753,16 @@ config-file-ts@^0.2.4: glob "^10.3.10" typescript "^5.3.3" +console-browserify@^1.1.0: + version "1.2.0" + resolved "https://registry.yarnpkg.com/console-browserify/-/console-browserify-1.2.0.tgz#67063cef57ceb6cf4993a2ab3a55840ae8c49336" + integrity sha512-ZMkYO/LkF17QvCPqM0gxw8yUzigAOZOSWSHg91FH6orS7vcEj5dVZTidN2fQ14yBSdg97RqhSNwLUXInd52OTA== + +constants-browserify@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/constants-browserify/-/constants-browserify-1.0.0.tgz#c20b96d8c617748aaf1c16021760cd27fcb8cb75" + integrity sha512-xFxOwqIzR/e1k1gLiWEophSCMqXcwVHIH7akf7b/vxcUeGunlj3hvZaaqxwHsTgn+IndtkQJgSztIDWeumWJDQ== + conventional-changelog-angular@^8.0.0: version "8.0.0" resolved "https://registry.yarnpkg.com/conventional-changelog-angular/-/conventional-changelog-angular-8.0.0.tgz#5701386850f0e0c2e630b43ee7821d322d87e7a6" @@ -2586,6 +2808,11 @@ core-util-is@1.0.2: resolved "https://registry.yarnpkg.com/core-util-is/-/core-util-is-1.0.2.tgz#b5fd54220aa2bc5ab57aab7140c940754503c1a7" integrity sha512-3lqz5YjWTYnW6dlDa5TLaTCcShfar1e40rmcJVwCBJC6mWlFuj0eCHIElmG1g5kyuJ/GD+8Wn4FFCcz4gJPfaQ== +core-util-is@~1.0.0: + version "1.0.3" + resolved "https://registry.yarnpkg.com/core-util-is/-/core-util-is-1.0.3.tgz#a6042d3634c2b27e9328f837b965fac83808db85" + integrity sha512-ZQBvi1DcpJ4GDqanjucZ2Hj3wEO5pZDS89BWbkcrvdxksJorwUDDZamX9ldFkp9aw2lmBDLgkObEA4DWNJ9FYQ== + crc@^3.8.0: version "3.8.0" resolved "https://registry.yarnpkg.com/crc/-/crc-3.8.0.tgz#ad60269c2c856f8c299e2c4cc0de4556914056c6" @@ -2593,6 +2820,42 @@ crc@^3.8.0: dependencies: buffer "^5.1.0" +create-ecdh@^4.0.0: + version "4.0.4" + resolved "https://registry.yarnpkg.com/create-ecdh/-/create-ecdh-4.0.4.tgz#d6e7f4bffa66736085a0762fd3a632684dabcc4e" + integrity sha512-mf+TCx8wWc9VpuxfP2ht0iSISLZnt0JgWlrOKZiNqyUZWnjIaCIVNQArMHnCZKfEYRg6IM7A+NeJoN8gf/Ws0A== + dependencies: + bn.js "^4.1.0" + elliptic "^6.5.3" + +create-hash@^1.1.0, create-hash@^1.1.2, create-hash@^1.2.0: + version "1.2.0" + resolved "https://registry.yarnpkg.com/create-hash/-/create-hash-1.2.0.tgz#889078af11a63756bcfb59bd221996be3a9ef196" + integrity sha512-z00bCGNHDG8mHAkP7CtT1qVu+bFQUPjYq/4Iv3C3kWjTFV10zIjfSoeqXo9Asws8gwSHDGj/hl2u4OGIjapeCg== + dependencies: + cipher-base "^1.0.1" + inherits "^2.0.1" + md5.js "^1.3.4" + ripemd160 "^2.0.1" + sha.js "^2.4.0" + +create-hmac@^1.1.0, create-hmac@^1.1.4, create-hmac@^1.1.7: + version "1.1.7" + resolved "https://registry.yarnpkg.com/create-hmac/-/create-hmac-1.1.7.tgz#69170c78b3ab957147b2b8b04572e47ead2243ff" + integrity sha512-MJG9liiZ+ogc4TzUwuvbER1JRdgvUFSB5+VR/g5h82fGaIRWMWddtKBHi7/sVhfjQZ6SehlyhvQYrcYkaUIpLg== + dependencies: + cipher-base "^1.0.3" + create-hash "^1.1.0" + inherits "^2.0.1" + ripemd160 "^2.0.0" + safe-buffer "^5.0.1" + sha.js "^2.4.8" + +create-require@^1.1.1: + version "1.1.1" + resolved "https://registry.yarnpkg.com/create-require/-/create-require-1.1.1.tgz#c1d7e8f1e5f6cfc9ff65f9cd352d37348756c333" + integrity sha512-dcKFX3jn0MpIaXjisoRvexIJVEKzaq7z2rZKxf+MSr9TkdmHmsU4m2lcLojrj/FHl8mk5VxMmYA+ftRkP/3oKQ== + cross-env@7.0.3: version "7.0.3" resolved "https://registry.yarnpkg.com/cross-env/-/cross-env-7.0.3.tgz#865264b29677dc015ba8418918965dd232fc54cf" @@ -2614,6 +2877,31 @@ crypt@0.0.2: resolved "https://registry.yarnpkg.com/crypt/-/crypt-0.0.2.tgz#88d7ff7ec0dfb86f713dc87bbb42d044d3e6c41b" integrity sha512-mCxBlsHFYh9C+HVpiEacem8FEBnMXgU9gy4zmNC+SXAZNB/1idgp/aulFJ4FgCi7GPEVbfyng092GqL2k2rmow== +crypto-browserify@^3.11.0: + version "3.12.0" + resolved "https://registry.yarnpkg.com/crypto-browserify/-/crypto-browserify-3.12.0.tgz#396cf9f3137f03e4b8e532c58f698254e00f80ec" + integrity sha512-fz4spIh+znjO2VjL+IdhEpRJ3YN6sMzITSBijk6FK2UvTqruSQW+/cCZTSNsMiZNvUeq0CqurF+dAbyiGOY6Wg== + dependencies: + browserify-cipher "^1.0.0" + browserify-sign "^4.0.0" + create-ecdh "^4.0.0" + create-hash "^1.1.0" + create-hmac "^1.1.0" + diffie-hellman "^5.0.0" + inherits "^2.0.1" + pbkdf2 "^3.0.3" + public-encrypt "^4.0.0" + randombytes "^2.0.0" + randomfill "^1.0.3" + +css-tree@^2.3.1: + version "2.3.1" + resolved "https://registry.yarnpkg.com/css-tree/-/css-tree-2.3.1.tgz#10264ce1e5442e8572fc82fbe490644ff54b5c20" + integrity sha512-6Fv1DV/TYw//QF5IzQdqsNDjx/wc8TrMBZsqjL9eW01tWb7R7k/mq+/VXfJCl7SoD5emsJop9cOByJZfs8hYIw== + dependencies: + mdn-data "2.0.30" + source-map-js "^1.0.1" + css.escape@^1.5.1: version "1.5.1" resolved "https://registry.yarnpkg.com/css.escape/-/css.escape-1.5.1.tgz#42e27d4fa04ae32f931a4b4d4191fa9cddee97cb" @@ -2668,7 +2956,7 @@ debug@4.3.4: dependencies: ms "2.1.2" -debug@^4.0.0: +debug@^4.0.0, debug@^4.3.6: version "4.3.7" resolved "https://registry.yarnpkg.com/debug/-/debug-4.3.7.tgz#87945b4151a011d76d95a198d7111c865c360a52" integrity sha512-Er2nc/H7RrMXZBFCEim6TCmMk02Z8vLC2Rbi1KEBggpo0fS6l0S1nnapwmIi3yW/+GOJap1Krg4w0Hg80oCqgQ== @@ -2721,7 +3009,7 @@ define-data-property@^1.0.1, define-data-property@^1.1.4: es-errors "^1.3.0" gopd "^1.0.1" -define-properties@^1.2.1: +define-properties@^1.1.3, define-properties@^1.2.1: version "1.2.1" resolved "https://registry.yarnpkg.com/define-properties/-/define-properties-1.2.1.tgz#10781cc616eb951a80a034bafcaa7377f6af2b6c" integrity sha512-8QmQKqEASLd5nx0U1B1okLElbUuuttJ/AnYmRXbbbGDWh6uS208EjD4Xqq/I9wK7u0v6O08XhTWnt5XtEbR6Dg== @@ -2749,6 +3037,14 @@ dequal@^2.0.3: resolved "https://registry.yarnpkg.com/dequal/-/dequal-2.0.3.tgz#2644214f1997d39ed0ee0ece72335490a7ac67be" integrity sha512-0je+qPKHEMohvfRTCEo3CrPG6cAzAYgmzKyxRiYSSDkS6eGJdyVJm7WaYA5ECaAD9wLB2T4EEeymA5aFVcYXCA== +des.js@^1.0.0: + version "1.1.0" + resolved "https://registry.yarnpkg.com/des.js/-/des.js-1.1.0.tgz#1d37f5766f3bbff4ee9638e871a8768c173b81da" + integrity sha512-r17GxjhUCjSRy8aiJpr8/UadFIzMzJGexI3Nmz4ADi9LYSFx4gTBp80+NaX/YsXWWLhpZ7v/v/ubEc/bCNfKwg== + dependencies: + inherits "^2.0.1" + minimalistic-assert "^1.0.0" + detect-libc@^2.0.0: version "2.0.3" resolved "https://registry.yarnpkg.com/detect-libc/-/detect-libc-2.0.3.tgz#f0cd503b40f9939b894697d19ad50895e30cf700" @@ -2769,6 +3065,15 @@ devtools-protocol@0.0.1299070: resolved "https://registry.yarnpkg.com/devtools-protocol/-/devtools-protocol-0.0.1299070.tgz#b3e4cf0b678a46f0f907ae6e07e03ad3a53c00df" integrity sha512-+qtL3eX50qsJ7c+qVyagqi7AWMoQCBGNfoyJZMwm/NSXVqLYbuitrWEEIzxfUmTNy7//Xe8yhMmQ+elj3uAqSg== +diffie-hellman@^5.0.0: + version "5.0.3" + resolved "https://registry.yarnpkg.com/diffie-hellman/-/diffie-hellman-5.0.3.tgz#40e8ee98f55a2149607146921c63e1ae5f3d2875" + integrity sha512-kqag/Nl+f3GwyK25fhUMYj81BUOrZ9IuJsjIcDE5icNM9FJHAVm3VcUDxdLPoQtTuUylWm6ZIknYJwwaPxsUzg== + dependencies: + bn.js "^4.1.0" + miller-rabin "^4.0.0" + randombytes "^2.0.0" + dir-compare@^3.0.0: version "3.3.0" resolved "https://registry.yarnpkg.com/dir-compare/-/dir-compare-3.3.0.tgz#2c749f973b5c4b5d087f11edaae730db31788416" @@ -2837,6 +3142,11 @@ dom-helpers@^5.0.1, dom-helpers@^5.2.0, dom-helpers@^5.2.1: "@babel/runtime" "^7.8.7" csstype "^3.0.2" +domain-browser@^4.22.0: + version "4.23.0" + resolved "https://registry.yarnpkg.com/domain-browser/-/domain-browser-4.23.0.tgz#427ebb91efcb070f05cffdfb8a4e9a6c25f8c94b" + integrity sha512-ArzcM/II1wCCujdCNyQjXrAFwS4mrLh4C7DZWlaI8mdh7h3BfKdNd3bKXITfl2PT9FtfQqaGvhi1vPRQPimjGA== + dot-prop@^5.1.0: version "5.3.0" resolved "https://registry.yarnpkg.com/dot-prop/-/dot-prop-5.3.0.tgz#90ccce708cd9cd82cc4dc8c3ddd9abdd55b20e88" @@ -2944,6 +3254,19 @@ electron@30.0.9: "@types/node" "^20.9.0" extract-zip "^2.0.1" +elliptic@^6.5.3, elliptic@^6.5.5: + version "6.5.7" + resolved "https://registry.yarnpkg.com/elliptic/-/elliptic-6.5.7.tgz#8ec4da2cb2939926a1b9a73619d768207e647c8b" + integrity sha512-ESVCtTwiA+XhY3wyh24QqRGBoP3rEdDUl3EDUUo9tft074fi19IrdpH7hLCMMP3CIj7jb3W96rn8lt/BqIlt5Q== + dependencies: + bn.js "^4.11.9" + brorand "^1.1.0" + hash.js "^1.0.0" + hmac-drbg "^1.0.1" + inherits "^2.0.4" + minimalistic-assert "^1.0.1" + minimalistic-crypto-utils "^1.0.1" + emittery@^1.0.3: version "1.0.3" resolved "https://registry.yarnpkg.com/emittery/-/emittery-1.0.3.tgz#c9d2a9c689870f15251bb13b31c67715c26d69ac" @@ -3140,9 +3463,9 @@ esprima@^4.0.1: integrity sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A== esquery@^1.4.2: - version "1.5.0" - resolved "https://registry.yarnpkg.com/esquery/-/esquery-1.5.0.tgz#6ce17738de8577694edd7361c57182ac8cb0db0b" - integrity sha512-YQLXUplAwJgCydQ78IMJywZCceoqk1oH01OERdSAJc/7U2AylwjhSCLDEtqwg811idIS/9fIU5GjG73IgjKMVg== + version "1.6.0" + resolved "https://registry.yarnpkg.com/esquery/-/esquery-1.6.0.tgz#91419234f804d852a82dceec3e16cdc22cf9dae7" + integrity sha512-ca9pw9fomFcKPvFLXhBKUK90ZvGibiGOvRJNbjljY7s7uq/5YO4BOzcYtJqExdx99rF6aAcnRxHmcUHcz6sQsg== dependencies: estraverse "^5.1.0" @@ -3163,7 +3486,7 @@ estree-walker@^2.0.2: resolved "https://registry.yarnpkg.com/estree-walker/-/estree-walker-2.0.2.tgz#52f010178c2a4c117a7757cfe942adb7d2da4cac" integrity sha512-Rfkk/Mp/DL7JVje3u18FxFujQlTNR2q6QfMSMB7AvCBx91NGj/ba3kCfza0f6dVDbw7YlRf/nDrn7pQrCCyQ/w== -estree-walker@^3.0.3: +estree-walker@^3.0.0, estree-walker@^3.0.3: version "3.0.3" resolved "https://registry.yarnpkg.com/estree-walker/-/estree-walker-3.0.3.tgz#67c3e549ec402a487b4fc193d1953a524752340d" integrity sha512-7RUKfXgSMMkzt6ZuXmqapOurLGPPfgj6l9uRZ7lRGolvk0y2yocc35LdcxKC5PQZdn2DMqioAQ2NoWcrTKmm6g== @@ -3175,25 +3498,18 @@ esutils@^2.0.2: resolved "https://registry.yarnpkg.com/esutils/-/esutils-2.0.3.tgz#74d2eb4de0b8da1293711910d50775b9b710ef64" integrity sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g== -events@^3.3.0: +events@^3.0.0, events@^3.3.0: version "3.3.0" resolved "https://registry.yarnpkg.com/events/-/events-3.3.0.tgz#31a95ad0a924e2d2c419a813aeb2c4e878ea7400" integrity sha512-mQw+2fkQbALzQ7V0MY0IqdnXNOeTtP4r0lN9z7AAawCXgqea7bDii20AYrIBrFd/Hx0M2Ocz6S111CaFkUcb0Q== -execa@^8.0.1: - version "8.0.1" - resolved "https://registry.yarnpkg.com/execa/-/execa-8.0.1.tgz#51f6a5943b580f963c3ca9c6321796db8cc39b8c" - integrity sha512-VyhnebXciFV2DESc+p6B+y0LjSm0krU4OgJN44qFAhBY0TJ+1V61tYD2+wHusZ6F9n5K+vl8k0sTy7PEfV4qpg== +evp_bytestokey@^1.0.0, evp_bytestokey@^1.0.3: + version "1.0.3" + resolved "https://registry.yarnpkg.com/evp_bytestokey/-/evp_bytestokey-1.0.3.tgz#7fcbdb198dc71959432efe13842684e0525acb02" + integrity sha512-/f2Go4TognH/KvCISP7OUsHn85hT9nUkxxA9BEWxFn+Oj9o8ZNLm/40hdlgSLyuOimsrTKLUMEorQexp/aPQeA== dependencies: - cross-spawn "^7.0.3" - get-stream "^8.0.1" - human-signals "^5.0.0" - is-stream "^3.0.0" - merge-stream "^2.0.0" - npm-run-path "^5.1.0" - onetime "^6.0.0" - signal-exit "^4.1.0" - strip-final-newline "^3.0.0" + md5.js "^1.3.4" + safe-buffer "^5.1.1" expand-template@^2.0.3: version "2.0.3" @@ -3326,6 +3642,13 @@ follow-redirects@^1.14.9: resolved "https://registry.yarnpkg.com/follow-redirects/-/follow-redirects-1.15.6.tgz#7f815c0cda4249c74ff09e95ef97c23b5fd0399b" integrity sha512-wWN62YITEaOpSK584EZXJafH1AGpO8RVgElfkuXbTOrPX4fIfOyEpW/CsiNd8JdYrAoOvafRTOEnvsO++qCqFA== +for-each@^0.3.3: + version "0.3.3" + resolved "https://registry.yarnpkg.com/for-each/-/for-each-0.3.3.tgz#69b447e88a0a5d32c3e7084f3f1710034b21376e" + integrity sha512-jqYfLp7mo9vIyQf8ykW2v7A+2N4QjeCeI5+Dz9XraiO1ign81wjiH7Fb9vSOWvQfNtmSa4H2RoQTrrXivdUZmw== + dependencies: + is-callable "^1.1.3" + foreground-child@^3.1.0: version "3.1.1" resolved "https://registry.yarnpkg.com/foreground-child/-/foreground-child-3.1.1.tgz#1d173e776d75d2772fed08efe4a0de1ea1b12d0d" @@ -3482,11 +3805,6 @@ get-stream@^5.1.0: dependencies: pump "^3.0.0" -get-stream@^8.0.1: - version "8.0.1" - resolved "https://registry.yarnpkg.com/get-stream/-/get-stream-8.0.1.tgz#def9dfd71742cd7754a7761ed43749a27d02eca2" - integrity sha512-VaUJspBffn/LMCJVoMvSAdmscJyS1auj5Zulnn5UoYcY531UWmdwhRWkcGKnGU93m5HSXP9LP2usOryrBtQowA== - get-uri@^6.0.1: version "6.0.3" resolved "https://registry.yarnpkg.com/get-uri/-/get-uri-6.0.3.tgz#0d26697bc13cf91092e519aa63aa60ee5b6f385a" @@ -3583,6 +3901,11 @@ globby@^11.1.0: merge2 "^1.4.1" slash "^3.0.0" +globrex@^0.1.2: + version "0.1.2" + resolved "https://registry.yarnpkg.com/globrex/-/globrex-0.1.2.tgz#dd5d9ec826232730cd6793a5e33a9302985e6098" + integrity sha512-uHJgbwAMwNFf5mLst7IWLNg14x1CkeqglJb/K3doi4dw6q2IvAAmM/Y81kevy83wP+Sst+nutFTYOGg3d1lsxg== + google-auth-library@^8.8.0: version "8.9.0" resolved "https://registry.yarnpkg.com/google-auth-library/-/google-auth-library-8.9.0.tgz#15a271eb2ec35d43b81deb72211bd61b1ef14dd0" @@ -3736,6 +4059,38 @@ has-symbols@^1.0.3: resolved "https://registry.yarnpkg.com/has-symbols/-/has-symbols-1.0.3.tgz#bb7b2c4349251dce87b125f7bdf874aa7c8b39f8" integrity sha512-l3LCuF6MgDNwTDKkdYGEihYjt5pRPbEg46rtlmnSPlUbgmB8LOIrKJbYYFBSbnPaJexMKtiPO8hmeRjRz2Td+A== +has-tostringtag@^1.0.0, has-tostringtag@^1.0.2: + version "1.0.2" + resolved "https://registry.yarnpkg.com/has-tostringtag/-/has-tostringtag-1.0.2.tgz#2cdc42d40bef2e5b4eeab7c01a73c54ce7ab5abc" + integrity sha512-NqADB8VjPFLM2V0VvHUewwwsw0ZWBaIdgo+ieHtK3hasLz4qeCRjYcqfB6AQrBggRKppKF8L52/VqdVsO47Dlw== + dependencies: + has-symbols "^1.0.3" + +hash-base@^3.0.0: + version "3.1.0" + resolved "https://registry.yarnpkg.com/hash-base/-/hash-base-3.1.0.tgz#55c381d9e06e1d2997a883b4a3fddfe7f0d3af33" + integrity sha512-1nmYp/rhMDiE7AYkDw+lLwlAzz0AntGIe51F3RfFfEqyQ3feY2eI/NcwC6umIQVOASPMsWJLJScWKSSvzL9IVA== + dependencies: + inherits "^2.0.4" + readable-stream "^3.6.0" + safe-buffer "^5.2.0" + +hash-base@~3.0: + version "3.0.4" + resolved "https://registry.yarnpkg.com/hash-base/-/hash-base-3.0.4.tgz#5fc8686847ecd73499403319a6b0a3f3f6ae4918" + integrity sha512-EeeoJKjTyt868liAlVmcv2ZsUfGHlE3Q+BICOXcZiwN3osr5Q/zFGYmTJpoIzuaSTAwndFy+GqhEwlU4L3j4Ow== + dependencies: + inherits "^2.0.1" + safe-buffer "^5.0.1" + +hash.js@^1.0.0, hash.js@^1.0.3: + version "1.1.7" + resolved "https://registry.yarnpkg.com/hash.js/-/hash.js-1.1.7.tgz#0babca538e8d4ee4a0f8988d68866537a003cf42" + integrity sha512-taOaskGt4z4SOANNseOviYDvjEJinIkRgmp7LbKP2YTTmVxWBl87s/uzK9r+44BclBSp2X7K1hqeNfz9JbBeXA== + dependencies: + inherits "^2.0.3" + minimalistic-assert "^1.0.1" + hasown@^2.0.0: version "2.0.2" resolved "https://registry.yarnpkg.com/hasown/-/hasown-2.0.2.tgz#003eaf91be7adc372e84ec59dc37252cedb80003" @@ -3743,6 +4098,15 @@ hasown@^2.0.0: dependencies: function-bind "^1.1.2" +hmac-drbg@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/hmac-drbg/-/hmac-drbg-1.0.1.tgz#d2745701025a6c775a6c545793ed502fc0c649a1" + integrity sha512-Tti3gMqLdZfhOQY1Mzf/AanLiqh1WTiJgEj26ZuYQ9fbkLomzGchCws4FyrSd4VkpBfiNhaE1On+lOz894jvXg== + dependencies: + hash.js "^1.0.3" + minimalistic-assert "^1.0.0" + minimalistic-crypto-utils "^1.0.1" + hosted-git-info@^4.1.0: version "4.1.0" resolved "https://registry.yarnpkg.com/hosted-git-info/-/hosted-git-info-4.1.0.tgz#827b82867e9ff1c8d0c4d9d53880397d2c86d224" @@ -3787,6 +4151,11 @@ http2-wrapper@^1.0.0-beta.5.2: quick-lru "^5.1.1" resolve-alpn "^1.0.0" +https-browserify@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/https-browserify/-/https-browserify-1.0.0.tgz#ec06c10e0a34c0f2faf199f7fd7fc78fffd03c73" + integrity sha512-J+FkSdyD+0mA0N+81tMotaRMfSL9SGi+xpD3T6YApKsc3bGSXJlfXri3VyFOeYkfLRQisDk1W+jIFFKBeUBbBg== + https-proxy-agent@^5.0.0, https-proxy-agent@^5.0.1: version "5.0.1" resolved "https://registry.yarnpkg.com/https-proxy-agent/-/https-proxy-agent-5.0.1.tgz#c59ef224a04fe8b754f3db0063a25ea30d0005d6" @@ -3811,11 +4180,6 @@ https-proxy-agent@^7.0.5: agent-base "^7.0.2" debug "4" -human-signals@^5.0.0: - version "5.0.0" - resolved "https://registry.yarnpkg.com/human-signals/-/human-signals-5.0.0.tgz#42665a284f9ae0dade3ba41ebc37eb4b852f3a28" - integrity sha512-AXcZb6vzzrFAUE61HnN4mpLqd/cSIwNQjtNWR0euPm6y0iqx3G4gOXaIDdtdDwZmhwe82LA6+zinmW4UBWVePQ== - iconv-corefoundation@^1.1.7: version "1.1.7" resolved "https://registry.yarnpkg.com/iconv-corefoundation/-/iconv-corefoundation-1.1.7.tgz#31065e6ab2c9272154c8b0821151e2c88f1b002a" @@ -3910,7 +4274,7 @@ inflight@^1.0.4: once "^1.3.0" wrappy "1" -inherits@2, inherits@^2.0.3, inherits@^2.0.4: +inherits@2, inherits@^2.0.1, inherits@^2.0.3, inherits@^2.0.4, inherits@~2.0.3, inherits@~2.0.4: version "2.0.4" resolved "https://registry.yarnpkg.com/inherits/-/inherits-2.0.4.tgz#0fa2c64f932917c3433a0ded55363aae37416b7c" integrity sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ== @@ -3935,6 +4299,14 @@ ip-address@^9.0.5: jsbn "1.1.0" sprintf-js "^1.1.3" +is-arguments@^1.0.4: + version "1.1.1" + resolved "https://registry.yarnpkg.com/is-arguments/-/is-arguments-1.1.1.tgz#15b3f88fda01f2a97fec84ca761a560f123efa9b" + integrity sha512-8Q7EARjzEnKpt/PCD7e1cgUS0a6X8u5tdSiMqXhojOdoV9TsMsiO+9VLC5vAmO8N7/GmXn7yjR8qnA6bVAEzfA== + dependencies: + call-bind "^1.0.2" + has-tostringtag "^1.0.0" + is-binary-path@~2.1.0: version "2.1.0" resolved "https://registry.yarnpkg.com/is-binary-path/-/is-binary-path-2.1.0.tgz#ea1f7f3b80f064236e83470f86c09c254fb45b09" @@ -3947,6 +4319,11 @@ is-buffer@~1.1.6: resolved "https://registry.yarnpkg.com/is-buffer/-/is-buffer-1.1.6.tgz#efaa2ea9daa0d7ab2ea13a97b2b8ad51fefbe8be" integrity sha512-NcdALwpXkTm5Zvvbk7owOUSvVvBKDgKP5/ewfXEznmQFfs4ZRmanOeKBTjRVjka3QFoN6XJ+9F3USqfHqTaU5w== +is-callable@^1.1.3: + version "1.2.7" + resolved "https://registry.yarnpkg.com/is-callable/-/is-callable-1.2.7.tgz#3bc2a85ea742d9e36205dcacdd72ca1fdc51b055" + integrity sha512-1BC0BVFhS/p0qtw6enp8e+8OD0UrK0oFLztSjNzhcKA3WDuJxxAPXzPuPtKkjEY9UUoEWlX/8fgKeu2S8i9JTA== + is-ci@^3.0.0: version "3.0.1" resolved "https://registry.yarnpkg.com/is-ci/-/is-ci-3.0.1.tgz#db6ecbed1bd659c43dac0f45661e7674103d1867" @@ -3971,6 +4348,13 @@ is-fullwidth-code-point@^3.0.0: resolved "https://registry.yarnpkg.com/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz#f116f8064fe90b3f7844a38997c0b75051269f1d" integrity sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg== +is-generator-function@^1.0.7: + version "1.0.10" + resolved "https://registry.yarnpkg.com/is-generator-function/-/is-generator-function-1.0.10.tgz#f1558baf1ac17e0deea7c0415c438351ff2b3c72" + integrity sha512-jsEjy9l3yiXEQ+PsXdmBwEPcOxaXWLspKdplFUVI9vq1iZgIekeC0L167qeu86czQaxed3q/Uzuw0swL0irL8A== + dependencies: + has-tostringtag "^1.0.0" + is-glob@^4.0.0, is-glob@^4.0.1, is-glob@^4.0.3, is-glob@~4.0.1: version "4.0.3" resolved "https://registry.yarnpkg.com/is-glob/-/is-glob-4.0.3.tgz#64f61e42cbbb2eec2071a9dac0b28ba1e65d5084" @@ -3978,6 +4362,14 @@ is-glob@^4.0.0, is-glob@^4.0.1, is-glob@^4.0.3, is-glob@~4.0.1: dependencies: is-extglob "^2.1.1" +is-nan@^1.3.2: + version "1.3.2" + resolved "https://registry.yarnpkg.com/is-nan/-/is-nan-1.3.2.tgz#043a54adea31748b55b6cd4e09aadafa69bd9e1d" + integrity sha512-E+zBKpQ2t6MEo1VsonYmluk9NxGrbzpeeLC2xIViuO2EjU2xsXsBPwTr3Ykv9l08UYEVEdWeRZNouaZqF6RN0w== + dependencies: + call-bind "^1.0.0" + define-properties "^1.1.3" + is-number@^7.0.0: version "7.0.0" resolved "https://registry.yarnpkg.com/is-number/-/is-number-7.0.0.tgz#7535345b896734d5f80c4d06c50955527a14f12b" @@ -3998,6 +4390,13 @@ is-potential-custom-element-name@^1.0.1: resolved "https://registry.yarnpkg.com/is-potential-custom-element-name/-/is-potential-custom-element-name-1.0.1.tgz#171ed6f19e3ac554394edf78caa05784a45bebb5" integrity sha512-bCYeRA2rVibKZd+s2625gGnGF/t7DSqDs4dP7CrLA1m7jKWz6pps0LpYLJN8Q64HtmPKJ1hrN3nzPNKFEKOUiQ== +is-reference@^3.0.0, is-reference@^3.0.1: + version "3.0.2" + resolved "https://registry.yarnpkg.com/is-reference/-/is-reference-3.0.2.tgz#154747a01f45cd962404ee89d43837af2cba247c" + integrity sha512-v3rht/LgVcsdZa3O2Nqs+NMowLOxeOm7Ay9+/ARQ2F+qEoANRcqrjAZKGN0v8ymUetZGgkp26LTnGT7H0Qo9Pg== + dependencies: + "@types/estree" "*" + is-retry-allowed@^1.1.0: version "1.2.0" resolved "https://registry.yarnpkg.com/is-retry-allowed/-/is-retry-allowed-1.2.0.tgz#d778488bd0a4666a3be8a1482b9f2baafedea8b4" @@ -4008,10 +4407,17 @@ is-stream@^2.0.0: resolved "https://registry.yarnpkg.com/is-stream/-/is-stream-2.0.1.tgz#fac1e3d53b97ad5a9d0ae9cef2389f5810a5c077" integrity sha512-hFoiJiTl63nn+kstHGBtewWSKnQLpyb155KHheA1l39uvtO9nWIop1p3udqPcUd/xbF1VLMO4n7OI6p7RbngDg== -is-stream@^3.0.0: - version "3.0.0" - resolved "https://registry.yarnpkg.com/is-stream/-/is-stream-3.0.0.tgz#e6bfd7aa6bef69f4f472ce9bb681e3e57b4319ac" - integrity sha512-LnQR4bZ9IADDRSkvpqMGvt/tEJWclzklNgSw48V5EAaAeDd6qGvN8ei6k5p0tvxSR171VmGyHuTiAOfxAbr8kA== +is-typed-array@^1.1.3: + version "1.1.13" + resolved "https://registry.yarnpkg.com/is-typed-array/-/is-typed-array-1.1.13.tgz#d6c5ca56df62334959322d7d7dd1cca50debe229" + integrity sha512-uZ25/bUAlUY5fR4OKT4rZQEBrzQWYV9ZJYGGsUmEJ6thodVJ1HX64ePQ6Z0qPWP+m+Uq6e9UugrE38jeYsDSMw== + dependencies: + which-typed-array "^1.1.14" + +isarray@~1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/isarray/-/isarray-1.0.0.tgz#bb935d48582cba168c06834957a54a3e07124f11" + integrity sha512-VLghIWNM6ELQzo7zwmcg0NmTVyWKYjvIeM83yjp0wRDTmUnrM678fQbcKBo6n2CJEF0szoG//ytg+TKla89ALQ== isbinaryfile@^4.0.8: version "4.0.10" @@ -4028,6 +4434,11 @@ isexe@^2.0.0: resolved "https://registry.yarnpkg.com/isexe/-/isexe-2.0.0.tgz#e8fbf374dc556ff8947a10dcb0572d633f2cfa10" integrity sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw== +isomorphic-timers-promises@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/isomorphic-timers-promises/-/isomorphic-timers-promises-1.0.1.tgz#e4137c24dbc54892de8abae3a4b5c1ffff381598" + integrity sha512-u4sej9B1LPSxTGKB/HiuzvEQnXH0ECYkSVQU39koSwmFAxhlEAFl9RdTvLv4TOTQUgBS5O3O5fwUxk6byBZ+IQ== + israeli-bank-scrapers-core@5.1.4: version "5.1.4" resolved "https://registry.yarnpkg.com/israeli-bank-scrapers-core/-/israeli-bank-scrapers-core-5.1.4.tgz#0f91084963524b51f87da9fc77a8e4d7daa8b93b" @@ -4237,6 +4648,11 @@ local-pkg@^0.5.0: mlly "^1.4.2" pkg-types "^1.0.3" +locate-character@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/locate-character/-/locate-character-3.0.0.tgz#0305c5b8744f61028ef5d01f444009e00779f974" + integrity sha512-SW13ws7BjaeJ6p7Q6CO2nchbYEc3X3J6WrmTTDto7yMPqVSZTUyY5Tjbid+Ab8gLnATtygYtiDIJGQRRn2ZOiA== + locate-path@^6.0.0: version "6.0.0" resolved "https://registry.yarnpkg.com/locate-path/-/locate-path-6.0.0.tgz#55321eb309febbc59c4801d931a72452a681d286" @@ -4339,7 +4755,7 @@ magic-string-ast@0.3.0: dependencies: magic-string "^0.30.2" -magic-string@^0.30.10: +magic-string@^0.30.10, magic-string@^0.30.11, magic-string@^0.30.3, magic-string@^0.30.4: version "0.30.11" resolved "https://registry.yarnpkg.com/magic-string/-/magic-string-0.30.11.tgz#301a6f93b3e8c2cb13ac1a7a673492c0dfd12954" integrity sha512-+Wri9p0QHMy+545hKww7YAu5NyzF8iomPL/RQazugQ9+Ez4Ic3mERMd8ZTX5rfK944j+560ZJi8iAwgak1Ac7A== @@ -4360,6 +4776,15 @@ matcher@^3.0.0: dependencies: escape-string-regexp "^4.0.0" +md5.js@^1.3.4: + version "1.3.5" + resolved "https://registry.yarnpkg.com/md5.js/-/md5.js-1.3.5.tgz#b5d07b8e3216e3e27cd728d72f70d1e6a342005f" + integrity sha512-xitP+WxNPcTTOgnTJcrhM0xvdPepipPSf3I8EIpGKeFLjt3PlJLIDG3u8EX53ZIubkb+5U2+3rELYpEhHhzdkg== + dependencies: + hash-base "^3.0.0" + inherits "^2.0.1" + safe-buffer "^5.1.2" + md5@^2.2.1: version "2.3.0" resolved "https://registry.yarnpkg.com/md5/-/md5-2.3.0.tgz#c3da9a6aae3a30b46b7b0c349b87b110dc3bda4f" @@ -4369,16 +4794,16 @@ md5@^2.2.1: crypt "0.0.2" is-buffer "~1.1.6" +mdn-data@2.0.30: + version "2.0.30" + resolved "https://registry.yarnpkg.com/mdn-data/-/mdn-data-2.0.30.tgz#ce4df6f80af6cfbe218ecd5c552ba13c4dfa08cc" + integrity sha512-GaqWWShW4kv/G9IEucWScBx9G1/vsFZZJUO+tD26M8J8z3Kw5RDQjaoZe03YAClgeS/SWPOcb4nkFBTEi5DUEA== + meow@^13.0.0: version "13.2.0" resolved "https://registry.yarnpkg.com/meow/-/meow-13.2.0.tgz#6b7d63f913f984063b3cc261b6e8800c4cd3474f" integrity sha512-pxQJQzB6djGPXh08dacEloMFopsOqGVRKFPYvPOt9XDZ1HasbgDZA74CJGreSU4G3Ak7EFJGoiH2auq+yXISgA== -merge-stream@^2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/merge-stream/-/merge-stream-2.0.0.tgz#52823629a14dd00c9770fb6ad47dc6310f2c1f60" - integrity sha512-abv/qOcuPfk3URPfDzmZU1LKmuw8kT+0nIHvKrKgFrwifol/doWcdA4ZqsWQ8ENrFKkd67Mfpo/LovbIUsbt3w== - merge2@^1.3.0, merge2@^1.4.1: version "1.4.1" resolved "https://registry.yarnpkg.com/merge2/-/merge2-1.4.1.tgz#4368892f885e907455a6fd7dc55c0c9d404990ae" @@ -4392,6 +4817,14 @@ micromatch@^4.0.2, micromatch@^4.0.4: braces "^3.0.3" picomatch "^2.3.1" +miller-rabin@^4.0.0: + version "4.0.1" + resolved "https://registry.yarnpkg.com/miller-rabin/-/miller-rabin-4.0.1.tgz#f080351c865b0dc562a8462966daa53543c78a4d" + integrity sha512-115fLhvZVqWwHPbClyntxEVfVDfl9DLLTuJvq3g2O/Oxi8AiNouAHvDSzHS0viUJc+V5vm3eq91Xwqn9dp4jRA== + dependencies: + bn.js "^4.0.0" + brorand "^1.0.1" + mime-db@1.52.0: version "1.52.0" resolved "https://registry.yarnpkg.com/mime-db/-/mime-db-1.52.0.tgz#bbabcdc02859f4987301c856e3387ce5ec43bf70" @@ -4409,11 +4842,6 @@ mime@^2.5.2: resolved "https://registry.yarnpkg.com/mime/-/mime-2.6.0.tgz#a2a682a95cd4d0cb1d6257e28f83da7e35800367" integrity sha512-USPkMeET31rOMiarsBNIHZKLGgvKc/LrjofAnBlOttf5ajRvqiRA8QsenbcooctK6d6Ts6aqZXBA+XbkKthiQg== -mimic-fn@^4.0.0: - version "4.0.0" - resolved "https://registry.yarnpkg.com/mimic-fn/-/mimic-fn-4.0.0.tgz#60a90550d5cb0b239cca65d893b1a53b29871ecc" - integrity sha512-vqiC06CuhBTUdZH+RYl8sFrL096vA45Ok5ISO6sE/Mr1jRbGH4Csnhi8f3wKVl7x8mO4Au7Ir9D3Oyv1VYMFJw== - mimic-response@^1.0.0: version "1.0.1" resolved "https://registry.yarnpkg.com/mimic-response/-/mimic-response-1.0.1.tgz#4923538878eef42063cb8a3e3b0798781487ab1b" @@ -4429,6 +4857,16 @@ min-indent@^1.0.0: resolved "https://registry.yarnpkg.com/min-indent/-/min-indent-1.0.1.tgz#a63f681673b30571fbe8bc25686ae746eefa9869" integrity sha512-I9jwMn07Sy/IwOj3zVkVik2JTvgpaykDZEigL6Rx6N9LbMywwUSMtxET+7lVoDLLd3O3IXwJwvuuns8UB/HeAg== +minimalistic-assert@^1.0.0, minimalistic-assert@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/minimalistic-assert/-/minimalistic-assert-1.0.1.tgz#2e194de044626d4a10e7f7fbc00ce73e83e4d5c7" + integrity sha512-UtJcAD4yEaGtjPezWuO9wC4nwUnVH/8/Im3yEHQP4b67cXlD/Qr9hdITCU1xDbSEXg2XKNaP8jsReV7vQd00/A== + +minimalistic-crypto-utils@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/minimalistic-crypto-utils/-/minimalistic-crypto-utils-1.0.1.tgz#f6c00c1c0b082246e5c4d99dfb8c7c083b2b582a" + integrity sha512-JIYlbt6g8i5jKfJ3xz7rF0LXmv2TkDxBLUkiBeZ7bAx4GnnNMr8xFpGnOxn6GhTEHx3SjRrZEoU+j04prX1ktg== + minimatch@^3.0.4, minimatch@^3.0.5, minimatch@^3.1.1, minimatch@^3.1.2: version "3.1.2" resolved "https://registry.yarnpkg.com/minimatch/-/minimatch-3.1.2.tgz#19cd194bfd3e428f049a70817c038d89ab4be35b" @@ -4622,6 +5060,39 @@ node-releases@^2.0.14: resolved "https://registry.yarnpkg.com/node-releases/-/node-releases-2.0.14.tgz#2ffb053bceb8b2be8495ece1ab6ce600c4461b0b" integrity sha512-y10wOWt8yZpqXmOgRo77WaHEmhYQYGNA6y421PKsKYWEK8aW+cqAphborZDhqfyKrbZEN92CN1X2KbafY2s7Yw== +node-stdlib-browser@^1.2.0: + version "1.2.1" + resolved "https://registry.yarnpkg.com/node-stdlib-browser/-/node-stdlib-browser-1.2.1.tgz#888fa104914af94143ca4d8a8980fe0ed242d2d1" + integrity sha512-dZezG3D88Lg22DwyjsDuUs7cCT/XGr8WwJgg/S3ZnkcWuPet2Tt/W1d2Eytb1Z73JpZv+XVCDI5TWv6UMRq0Gg== + dependencies: + assert "^2.0.0" + browser-resolve "^2.0.0" + browserify-zlib "^0.2.0" + buffer "^5.7.1" + console-browserify "^1.1.0" + constants-browserify "^1.0.0" + create-require "^1.1.1" + crypto-browserify "^3.11.0" + domain-browser "^4.22.0" + events "^3.0.0" + https-browserify "^1.0.0" + isomorphic-timers-promises "^1.0.1" + os-browserify "^0.3.0" + path-browserify "^1.0.1" + pkg-dir "^5.0.0" + process "^0.11.10" + punycode "^1.4.1" + querystring-es3 "^0.2.1" + readable-stream "^3.6.0" + stream-browserify "^3.0.0" + stream-http "^3.2.0" + string_decoder "^1.0.0" + timers-browserify "^2.0.4" + tty-browserify "0.0.1" + url "^0.11.4" + util "^0.12.4" + vm-browserify "^1.0.1" + normalize-path@^3.0.0, normalize-path@~3.0.0: version "3.0.0" resolved "https://registry.yarnpkg.com/normalize-path/-/normalize-path-3.0.0.tgz#0dcd69ff23a1c9b11fd0978316644a0388216a65" @@ -4632,13 +5103,6 @@ normalize-url@^6.0.1: resolved "https://registry.yarnpkg.com/normalize-url/-/normalize-url-6.1.0.tgz#40d0885b535deffe3f3147bec877d05fe4c5668a" integrity sha512-DlL+XwOy3NxAQ8xuC0okPgK46iuVNAK01YN7RueYBqqFeGsBjV9XmCAzAdgt+667bCl5kPh9EqKKDwnaPG1I7A== -npm-run-path@^5.1.0: - version "5.3.0" - resolved "https://registry.yarnpkg.com/npm-run-path/-/npm-run-path-5.3.0.tgz#e23353d0ebb9317f174e93417e4a4d82d0249e9f" - integrity sha512-ppwTtiJZq0O/ai0z7yfudtBpWIoxM8yE6nHi1X47eFR2EWORqfbu6CnPlNsjeN683eT0qG6H/Pyf9fCcvjnnnQ== - dependencies: - path-key "^4.0.0" - nwsapi@^2.2.12: version "2.2.12" resolved "https://registry.yarnpkg.com/nwsapi/-/nwsapi-2.2.12.tgz#fb6af5c0ec35b27b4581eb3bbad34ec9e5c696f8" @@ -4654,11 +5118,29 @@ object-inspect@^1.13.1: resolved "https://registry.yarnpkg.com/object-inspect/-/object-inspect-1.13.1.tgz#b96c6109324ccfef6b12216a956ca4dc2ff94bc2" integrity sha512-5qoj1RUiKOMsCCNLV1CBiPYE10sziTsnmNxkAI/rZhiD63CF7IqdFGC/XzjWjpSgLf0LxXX3bDFIh0E18f6UhQ== +object-is@^1.1.5: + version "1.1.6" + resolved "https://registry.yarnpkg.com/object-is/-/object-is-1.1.6.tgz#1a6a53aed2dd8f7e6775ff870bea58545956ab07" + integrity sha512-F8cZ+KfGlSGi09lJT7/Nd6KJZ9ygtvYC0/UYYLI9nmQKLMnydpB9yvbv9K1uSkEu7FU9vYPmVwLg328tX+ot3Q== + dependencies: + call-bind "^1.0.7" + define-properties "^1.2.1" + object-keys@^1.1.1: version "1.1.1" resolved "https://registry.yarnpkg.com/object-keys/-/object-keys-1.1.1.tgz#1c47f272df277f3b1daf061677d9c82e2322c60e" integrity sha512-NuAESUOUMrlIXOfHKzD6bpPu3tYt3xvjNdRIQ+FeT0lNb4K8WR70CaDxhuNguS2XG+GjkyMwOzsN5ZktImfhLA== +object.assign@^4.1.4: + version "4.1.5" + resolved "https://registry.yarnpkg.com/object.assign/-/object.assign-4.1.5.tgz#3a833f9ab7fdb80fc9e8d2300c803d216d8fdbb0" + integrity sha512-byy+U7gp+FVwmyzKPYhW2h5l3crpmGsxl7X2s8y43IgxvG4g3QZ6CffDtsNQy1WsmZpQbO+ybo0AlW7TY6DcBQ== + dependencies: + call-bind "^1.0.5" + define-properties "^1.2.1" + has-symbols "^1.0.3" + object-keys "^1.1.1" + obuf@~1.1.2: version "1.1.2" resolved "https://registry.yarnpkg.com/obuf/-/obuf-1.1.2.tgz#09bea3343d41859ebd446292d11c9d4db619084e" @@ -4671,13 +5153,6 @@ once@^1.3.0, once@^1.3.1, once@^1.4.0: dependencies: wrappy "1" -onetime@^6.0.0: - version "6.0.0" - resolved "https://registry.yarnpkg.com/onetime/-/onetime-6.0.0.tgz#7c24c18ed1fd2e9bca4bd26806a33613c77d34b4" - integrity sha512-1FlR+gjXK7X+AsAHso35MnyN5KqGwJRi/31ft6x0M194ht7S+rWAvd7PHss9xSKMzE0asv1pyIHaJYq+BbacAQ== - dependencies: - mimic-fn "^4.0.0" - opentelemetry-instrumentation-fetch-node@1.2.0: version "1.2.0" resolved "https://registry.yarnpkg.com/opentelemetry-instrumentation-fetch-node/-/opentelemetry-instrumentation-fetch-node-1.2.0.tgz#5beaad33b622f7021c61733af864fb505cd35626" @@ -4699,6 +5174,11 @@ optionator@^0.9.3: type-check "^0.4.0" word-wrap "^1.2.5" +os-browserify@^0.3.0: + version "0.3.0" + resolved "https://registry.yarnpkg.com/os-browserify/-/os-browserify-0.3.0.tgz#854373c7f5c2315914fc9bfc6bd8238fdda1ec27" + integrity sha512-gjcpUc3clBf9+210TRaDWbf+rZZZEshZ+DlXMRCeAjp0xhTrnQsKHypIy1J3d5hKdUzj69t708EHtU8P6bUn0A== + p-cancelable@^2.0.0: version "2.1.1" resolved "https://registry.yarnpkg.com/p-cancelable/-/p-cancelable-2.1.1.tgz#aab7fbd416582fa32a3db49859c122487c5ed2cf" @@ -4740,6 +5220,11 @@ pac-resolver@^7.0.0: degenerator "^5.0.0" netmask "^2.0.2" +pako@~1.0.5: + version "1.0.11" + resolved "https://registry.yarnpkg.com/pako/-/pako-1.0.11.tgz#6c9599d340d54dfd3946380252a35705a6b992bf" + integrity sha512-4hLB8Py4zZce5s4yd9XzopqwVv/yGNhV1Bl8NTmCq1763HeK2+EwVTv+leGeL13Dnh2wfbqowVPXCIO0z4taYw== + parent-module@^1.0.0: version "1.0.1" resolved "https://registry.yarnpkg.com/parent-module/-/parent-module-1.0.1.tgz#691d2709e78c79fae3a156622452d00762caaaa2" @@ -4747,6 +5232,18 @@ parent-module@^1.0.0: dependencies: callsites "^3.0.0" +parse-asn1@^5.0.0, parse-asn1@^5.1.7: + version "5.1.7" + resolved "https://registry.yarnpkg.com/parse-asn1/-/parse-asn1-5.1.7.tgz#73cdaaa822125f9647165625eb45f8a051d2df06" + integrity sha512-CTM5kuWR3sx9IFamcl5ErfPl6ea/N8IYwiJ+vpeB2g+1iknv7zBl5uPwbMbRVznRVbrNY6lGuDoE5b30grmbqg== + dependencies: + asn1.js "^4.10.1" + browserify-aes "^1.2.0" + evp_bytestokey "^1.0.3" + hash-base "~3.0" + pbkdf2 "^3.1.2" + safe-buffer "^5.2.1" + parse5@^7.1.2: version "7.1.2" resolved "https://registry.yarnpkg.com/parse5/-/parse5-7.1.2.tgz#0736bebbfd77793823240a23b7fc5e010b7f8e32" @@ -4754,6 +5251,11 @@ parse5@^7.1.2: dependencies: entities "^4.4.0" +path-browserify@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/path-browserify/-/path-browserify-1.0.1.tgz#d98454a9c3753d5790860f16f68867b9e46be1fd" + integrity sha512-b7uo2UCUOYZcnF/3ID0lulOJi/bafxa1xPe7ZPsammBSpjSWQkjNxlt635YGS2MiR9GjvuXCtz2emr3jbsz98g== + path-exists@^4.0.0: version "4.0.0" resolved "https://registry.yarnpkg.com/path-exists/-/path-exists-4.0.0.tgz#513bdbe2d3b95d7762e8c1137efa195c6c61b5b3" @@ -4769,11 +5271,6 @@ path-key@^3.1.0: resolved "https://registry.yarnpkg.com/path-key/-/path-key-3.1.1.tgz#581f6ade658cbba65a0d3380de7753295054f375" integrity sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q== -path-key@^4.0.0: - version "4.0.0" - resolved "https://registry.yarnpkg.com/path-key/-/path-key-4.0.0.tgz#295588dc3aee64154f877adb9d780b81c554bf18" - integrity sha512-haREypq7xkM7ErfgIyA0z+Bj4AGKlMSdlQE2jvJo6huWD1EdkKYV+G/T4nq0YEF2vgTT8kqMFKo1uHn950r4SQ== - path-parse@^1.0.7: version "1.0.7" resolved "https://registry.yarnpkg.com/path-parse/-/path-parse-1.0.7.tgz#fbc114b60ca42b30d9daf5858e4bd68bbedb6735" @@ -4802,11 +5299,31 @@ pathval@^2.0.0: resolved "https://registry.yarnpkg.com/pathval/-/pathval-2.0.0.tgz#7e2550b422601d4f6b8e26f1301bc8f15a741a25" integrity sha512-vE7JKRyES09KiunauX7nd2Q9/L7lhok4smP9RZTDeD4MVs72Dp2qNFVz39Nz5a0FVEW0BJR6C0DYrq6unoziZA== +pbkdf2@^3.0.3, pbkdf2@^3.1.2: + version "3.1.2" + resolved "https://registry.yarnpkg.com/pbkdf2/-/pbkdf2-3.1.2.tgz#dd822aa0887580e52f1a039dc3eda108efae3075" + integrity sha512-iuh7L6jA7JEGu2WxDwtQP1ddOpaJNC4KlDEFfdQajSGgGPNi4OyDc2R7QnbY2bR9QjBVGwgvTdNJZoE7RaxUMA== + dependencies: + create-hash "^1.1.2" + create-hmac "^1.1.4" + ripemd160 "^2.0.1" + safe-buffer "^5.0.1" + sha.js "^2.4.8" + pend@~1.2.0: version "1.2.0" resolved "https://registry.yarnpkg.com/pend/-/pend-1.2.0.tgz#7a57eb550a6783f9115331fcf4663d5c8e007a50" integrity sha512-F3asv42UuXchdzt+xXqfW1OGlVBe+mxa2mqI0pg5yAHZPvFmY3Y6drSf/GQ1A86WgWEN9Kzh/WrgKa6iGcHXLg== +periscopic@^3.1.0: + version "3.1.0" + resolved "https://registry.yarnpkg.com/periscopic/-/periscopic-3.1.0.tgz#7e9037bf51c5855bd33b48928828db4afa79d97a" + integrity sha512-vKiQ8RRtkl9P+r/+oefh25C3fhybptkHKCZSPlcXiJux2tJF55GnEj3BVn4A5gKfq9NWWXXrxkHBwVPUfH0opw== + dependencies: + "@types/estree" "^1.0.0" + estree-walker "^3.0.0" + is-reference "^3.0.0" + pg-int8@1.0.1: version "1.0.1" resolved "https://registry.yarnpkg.com/pg-int8/-/pg-int8-1.0.1.tgz#943bd463bf5b71b4170115f80f8efc9a0c0eb78c" @@ -4856,6 +5373,13 @@ picomatch@^2.0.4, picomatch@^2.2.1, picomatch@^2.3.1: resolved "https://registry.yarnpkg.com/picomatch/-/picomatch-2.3.1.tgz#3ba3833733646d9d3e4995946c1365a67fb07a42" integrity sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA== +pkg-dir@^5.0.0: + version "5.0.0" + resolved "https://registry.yarnpkg.com/pkg-dir/-/pkg-dir-5.0.0.tgz#a02d6aebe6ba133a928f74aec20bafdfe6b8e760" + integrity sha512-NPE8TDbzl/3YQYY7CSS228s3g2ollTFnc+Qi3tqmqJp9Vg2ovUpixcJEo2HJScN2Ez+kEaal6y70c0ehqJBJeA== + dependencies: + find-up "^5.0.0" + pkg-types@^1.0.3, pkg-types@^1.1.0: version "1.1.1" resolved "https://registry.yarnpkg.com/pkg-types/-/pkg-types-1.1.1.tgz#07b626880749beb607b0c817af63aac1845a73f2" @@ -4888,6 +5412,11 @@ plist@^3.0.4, plist@^3.0.5: base64-js "^1.5.1" xmlbuilder "^15.1.1" +possible-typed-array-names@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/possible-typed-array-names/-/possible-typed-array-names-1.0.0.tgz#89bb63c6fada2c3e90adc4a647beeeb39cc7bf8f" + integrity sha512-d7Uw+eZoloe0EHDIYoe+bQ5WXnGMOpmiZFTuMWCwpjzzkL2nTjcKiAk4hh8TjnGye2TwWOk3UXucZ+3rbmBa8Q== + postcss@^8.4.38: version "8.4.38" resolved "https://registry.yarnpkg.com/postcss/-/postcss-8.4.38.tgz#b387d533baf2054288e337066d81c6bee9db9e0e" @@ -4988,6 +5517,16 @@ pretty-format@^27.0.2: ansi-styles "^5.0.0" react-is "^17.0.1" +process-nextick-args@~2.0.0: + version "2.0.1" + resolved "https://registry.yarnpkg.com/process-nextick-args/-/process-nextick-args-2.0.1.tgz#7820d9b16120cc55ca9ae7792680ae7dba6d7fe2" + integrity sha512-3ouUOpQhtgrbOa17J7+uxOTpITYWaGP7/AhoR3+A+/1e9skrzelGi/dXzEYyvbxubEF6Wn2ypscTKiKJFFn1ag== + +process@^0.11.10: + version "0.11.10" + resolved "https://registry.yarnpkg.com/process/-/process-0.11.10.tgz#7332300e840161bda3e69a1d1d91a7d4bc16f182" + integrity sha512-cdGef/drWFoydD1JsMzuFf8100nZl+GT+yacc2bEced5f9Rjk4z+WtFUTBu9PhOi9j/jfmBPu0mMEY4wIdAF8A== + progress@2.0.3, progress@^2.0.3: version "2.0.3" resolved "https://registry.yarnpkg.com/progress/-/progress-2.0.3.tgz#7e8cf8d8f5b8f239c1bc68beb4eb78567d572ef8" @@ -5042,6 +5581,18 @@ psl@^1.1.33: resolved "https://registry.yarnpkg.com/psl/-/psl-1.9.0.tgz#d0df2a137f00794565fcaf3b2c00cd09f8d5a5a7" integrity sha512-E/ZsdU4HLs/68gYzgGTkMicWTLPdAftJLfJFlLUAAKZGkStNU72sZjT66SnMDVOfOWY/YAoiD7Jxa9iHvngcag== +public-encrypt@^4.0.0: + version "4.0.3" + resolved "https://registry.yarnpkg.com/public-encrypt/-/public-encrypt-4.0.3.tgz#4fcc9d77a07e48ba7527e7cbe0de33d0701331e0" + integrity sha512-zVpa8oKZSz5bTMTFClc1fQOnyyEzpl5ozpi1B5YcvBrdohMjH2rfsBtyXcuNuwjsDIXmBYlF2N5FlJYhR29t8Q== + dependencies: + bn.js "^4.1.0" + browserify-rsa "^4.0.0" + create-hash "^1.1.0" + parse-asn1 "^5.0.0" + randombytes "^2.0.1" + safe-buffer "^5.1.2" + pump@^3.0.0: version "3.0.0" resolved "https://registry.yarnpkg.com/pump/-/pump-3.0.0.tgz#b4a2116815bde2f4e1ea602354e8c75565107a64" @@ -5050,6 +5601,11 @@ pump@^3.0.0: end-of-stream "^1.1.0" once "^1.3.1" +punycode@^1.4.1: + version "1.4.1" + resolved "https://registry.yarnpkg.com/punycode/-/punycode-1.4.1.tgz#c0d5a63b2718800ad8e1eb0fa5269c84dd41845e" + integrity sha512-jmYNElW7yvO7TV33CjSmvSiE2yco3bV2czu/OzDKdMNVZQWfxCblURLhf+47syQRBntjfLdd/H0egrzIG+oaFQ== + punycode@^2.1.0, punycode@^2.1.1, punycode@^2.3.1: version "2.3.1" resolved "https://registry.yarnpkg.com/punycode/-/punycode-2.3.1.tgz#027422e2faec0b25e1549c3e1bd8309b9133b6e5" @@ -5077,6 +5633,13 @@ puppeteer-core@^22.10.0: devtools-protocol "0.0.1286932" ws "8.17.0" +qs@^6.12.3: + version "6.13.0" + resolved "https://registry.yarnpkg.com/qs/-/qs-6.13.0.tgz#6ca3bd58439f7e245655798997787b0d88a51906" + integrity sha512-+38qI9SOr8tfZ4QmJNplMUxqjbe7LKvvZgWdExBOmd+egZTtjLB67Gu0HRX3u/XOq7UU2Nx6nsjvS16Z9uwfpg== + dependencies: + side-channel "^1.0.6" + qs@^6.7.0: version "6.12.1" resolved "https://registry.yarnpkg.com/qs/-/qs-6.12.1.tgz#39422111ca7cbdb70425541cba20c7d7b216599a" @@ -5084,6 +5647,11 @@ qs@^6.7.0: dependencies: side-channel "^1.0.6" +querystring-es3@^0.2.1: + version "0.2.1" + resolved "https://registry.yarnpkg.com/querystring-es3/-/querystring-es3-0.2.1.tgz#9ec61f79049875707d69414596fd907a4d711e73" + integrity sha512-773xhDQnZBMFobEiztv8LIl70ch5MSF/jUQVlhwFyBILqq96anmoctVIYz+ZRp0qbCKATTn6ev02M3r7Ga5vqA== + querystringify@^2.1.1: version "2.2.0" resolved "https://registry.yarnpkg.com/querystringify/-/querystringify-2.2.0.tgz#3345941b4153cb9d082d8eee4cda2016a9aef7f6" @@ -5104,6 +5672,21 @@ quick-lru@^5.1.1: resolved "https://registry.yarnpkg.com/quick-lru/-/quick-lru-5.1.1.tgz#366493e6b3e42a3a6885e2e99d18f80fb7a8c932" integrity sha512-WuyALRjWPDGtt/wzJiadO5AXY+8hZ80hVpe6MyivgraREW751X3SbhRvG3eLKOYN+8VEvqLcf3wdnt44Z4S4SA== +randombytes@^2.0.0, randombytes@^2.0.1, randombytes@^2.0.5: + version "2.1.0" + resolved "https://registry.yarnpkg.com/randombytes/-/randombytes-2.1.0.tgz#df6f84372f0270dc65cdf6291349ab7a473d4f2a" + integrity sha512-vYl3iOX+4CKUWuxGi9Ukhie6fsqXqS9FE2Zaic4tNFD2N2QQaXOMFbuKK4QmDHC0JO6B1Zp41J0LpT0oR68amQ== + dependencies: + safe-buffer "^5.1.0" + +randomfill@^1.0.3: + version "1.0.4" + resolved "https://registry.yarnpkg.com/randomfill/-/randomfill-1.0.4.tgz#c92196fc86ab42be983f1bf31778224931d61458" + integrity sha512-87lcbR8+MhcWcUiQ+9e+Rwx8MyR2P7qnt15ynUlbm3TU/fjbgz4GsvfSUDTemtCCtVCqb4ZcEFlyPNTh9bBTLw== + dependencies: + randombytes "^2.0.5" + safe-buffer "^5.1.0" + rc@^1.2.7: version "1.2.8" resolved "https://registry.yarnpkg.com/rc/-/rc-1.2.8.tgz#cd924bf5200a075b83c188cd6b9e211b7fc0d3ed" @@ -5248,7 +5831,20 @@ read-config-file@6.3.2: json5 "^2.2.0" lazy-val "^1.0.4" -readable-stream@^3.1.1, readable-stream@^3.4.0: +readable-stream@^2.3.8: + version "2.3.8" + resolved "https://registry.yarnpkg.com/readable-stream/-/readable-stream-2.3.8.tgz#91125e8042bba1b9887f49345f6277027ce8be9b" + integrity sha512-8p0AUk4XODgIewSi0l8Epjs+EVnWiK7NoDIEGU0HhE7+ZyY8D1IMY7odu5lRrFXGg71L15KG8QrPmum45RTtdA== + dependencies: + core-util-is "~1.0.0" + inherits "~2.0.3" + isarray "~1.0.0" + process-nextick-args "~2.0.0" + safe-buffer "~5.1.1" + string_decoder "~1.1.1" + util-deprecate "~1.0.1" + +readable-stream@^3.1.1, readable-stream@^3.4.0, readable-stream@^3.5.0, readable-stream@^3.6.0: version "3.6.2" resolved "https://registry.yarnpkg.com/readable-stream/-/readable-stream-3.6.2.tgz#56a9b36ea965c00c5a93ef31eb111a0f11056967" integrity sha512-9u/sniCrY3D5WdsERHzHE4G2YCXqoG5FTHUiCC4SIbr6XcLZBY05ya9EKjYek9O5xOAwjGq+1JdGBAS7Q9ScoA== @@ -5311,7 +5907,7 @@ resolve-from@^4.0.0: resolved "https://registry.yarnpkg.com/resolve-from/-/resolve-from-4.0.0.tgz#4abcd852ad32dd7baabfe9b40e00a36db5f392e6" integrity sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g== -resolve@^1.22.1: +resolve@^1.17.0, resolve@^1.22.1: version "1.22.8" resolved "https://registry.yarnpkg.com/resolve/-/resolve-1.22.8.tgz#b6c87a9f2aa06dfab52e3d70ac8cde321fa5a48d" integrity sha512-oKWePCxqpd6FlLvGV1VU0x7bkPmmCNolxzjMf4NczoDnQcIWrAF+cPtZn5i6n+RfD2d9i0tzpKnG6Yk168yIyw== @@ -5344,6 +5940,14 @@ rimraf@^3.0.2: dependencies: glob "^7.1.3" +ripemd160@^2.0.0, ripemd160@^2.0.1: + version "2.0.2" + resolved "https://registry.yarnpkg.com/ripemd160/-/ripemd160-2.0.2.tgz#a1c1a6f624751577ba5d07914cbc92850585890c" + integrity sha512-ii4iagi25WusVoiC4B4lq7pbXfAp3D9v5CwfkY33vffw2+pkDjY1D8GaN7spsxvCSx8dkPqOZCEZyfxcmJG2IA== + dependencies: + hash-base "^3.0.0" + inherits "^2.0.1" + roarr@^2.15.3: version "2.15.4" resolved "https://registry.yarnpkg.com/roarr/-/roarr-2.15.4.tgz#f5fe795b7b838ccfe35dc608e0282b9eba2e7afd" @@ -5398,11 +6002,16 @@ run-parallel@^1.1.9: dependencies: queue-microtask "^1.2.2" -safe-buffer@^5.0.1, safe-buffer@~5.2.0: +safe-buffer@^5.0.1, safe-buffer@^5.1.0, safe-buffer@^5.1.1, safe-buffer@^5.1.2, safe-buffer@^5.2.0, safe-buffer@^5.2.1, safe-buffer@~5.2.0: version "5.2.1" resolved "https://registry.yarnpkg.com/safe-buffer/-/safe-buffer-5.2.1.tgz#1eaf9fa9bdb1fdd4ec75f58f9cdb4e6b7827eec6" integrity sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ== +safe-buffer@~5.1.0, safe-buffer@~5.1.1: + version "5.1.2" + resolved "https://registry.yarnpkg.com/safe-buffer/-/safe-buffer-5.1.2.tgz#991ec69d296e0313747d59bdfd2b745c35f8828d" + integrity sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g== + "safer-buffer@>= 2.1.2 < 3.0.0": version "2.1.2" resolved "https://registry.yarnpkg.com/safer-buffer/-/safer-buffer-2.1.2.tgz#44fa161b0187b9549dd84bb91802f9bd8385cd6a" @@ -5487,6 +6096,19 @@ set-function-length@^1.2.1: gopd "^1.0.1" has-property-descriptors "^1.0.2" +setimmediate@^1.0.4: + version "1.0.5" + resolved "https://registry.yarnpkg.com/setimmediate/-/setimmediate-1.0.5.tgz#290cbb232e306942d7d7ea9b83732ab7856f8285" + integrity sha512-MATJdZp8sLqDl/68LfQmbP8zKPLQNV6BIZoIgrscFDQ+RsvK/BxeDQOgyxKKoh0y/8h3BqVFnCqQ/gd+reiIXA== + +sha.js@^2.4.0, sha.js@^2.4.8: + version "2.4.11" + resolved "https://registry.yarnpkg.com/sha.js/-/sha.js-2.4.11.tgz#37a5cf0b81ecbc6943de109ba2960d1b26584ae7" + integrity sha512-QMEp5B7cftE7APOjk5Y6xgrbWu+WkLVQwk8JNjZ8nKRciZaByEW6MubieAiToS7+dwvrjGhH8jRXz3MVd0AYqQ== + dependencies: + inherits "^2.0.1" + safe-buffer "^5.0.1" + shebang-command@^2.0.0: version "2.0.0" resolved "https://registry.yarnpkg.com/shebang-command/-/shebang-command-2.0.0.tgz#ccd0af4f8835fbdc265b82461aaf0c36663f34ea" @@ -5519,7 +6141,7 @@ siginfo@^2.0.0: resolved "https://registry.yarnpkg.com/siginfo/-/siginfo-2.0.0.tgz#32e76c70b79724e3bb567cb9d543eb858ccfaf30" integrity sha512-ybx0WO1/8bSBLEWXZvEd7gMW3Sn3JFlW3TvX1nREbDLRNQNaeNN8WK0meBwPdAaOI7TtRRRJn/Es1zhrrCHu7g== -signal-exit@^4.0.1, signal-exit@^4.1.0: +signal-exit@^4.0.1: version "4.1.0" resolved "https://registry.yarnpkg.com/signal-exit/-/signal-exit-4.1.0.tgz#952188c1cbd546070e2dd20d0f41c0ae0530cb04" integrity sha512-bzyZ1e88w9O1iNJbKnOlvYTrWPDl46O1bG0D3XInv+9tkPrxrN8jUUTiFlDkkmKWgn1M6CfIA13SuGqOa9Korw== @@ -5586,6 +6208,11 @@ socks@^2.7.1: ip-address "^9.0.5" smart-buffer "^4.2.0" +source-map-js@^1.0.1: + version "1.2.1" + resolved "https://registry.yarnpkg.com/source-map-js/-/source-map-js-1.2.1.tgz#1ce5650fddd87abc099eda37dcff024c2667ae46" + integrity sha512-UXWMKhLOwVKb728IUtQPXxfYU+usdybtUrK/8uGE8CQMvrhOpwvzDBwj0QhSL7MQc7vIsISBG8VQ8+IDQxpfQA== + source-map-js@^1.2.0: version "1.2.0" resolved "https://registry.yarnpkg.com/source-map-js/-/source-map-js-1.2.0.tgz#16b809c162517b5b8c3e7dcd315a2a5c2612b2af" @@ -5624,6 +6251,24 @@ std-env@^3.7.0: resolved "https://registry.yarnpkg.com/std-env/-/std-env-3.7.0.tgz#c9f7386ced6ecf13360b6c6c55b8aaa4ef7481d2" integrity sha512-JPbdCEQLj1w5GilpiHAx3qJvFndqybBysA3qUOnznweH4QbNYUsW/ea8QzSrnh0vNsezMMw5bcVool8lM0gwzg== +stream-browserify@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/stream-browserify/-/stream-browserify-3.0.0.tgz#22b0a2850cdf6503e73085da1fc7b7d0c2122f2f" + integrity sha512-H73RAHsVBapbim0tU2JwwOiXUj+fikfiaoYAKHF3VJfA0pe2BCzkhAHBlLG6REzE+2WNZcxOXjK7lkso+9euLA== + dependencies: + inherits "~2.0.4" + readable-stream "^3.5.0" + +stream-http@^3.2.0: + version "3.2.0" + resolved "https://registry.yarnpkg.com/stream-http/-/stream-http-3.2.0.tgz#1872dfcf24cb15752677e40e5c3f9cc1926028b5" + integrity sha512-Oq1bLqisTyK3TSCXpPbT4sdeYNdmyZJv1LxpEm2vu1ZhK89kSE5YXwZc3cWk0MagGaKriBh9mCFbVGtO+vY29A== + dependencies: + builtin-status-codes "^3.0.0" + inherits "^2.0.4" + readable-stream "^3.6.0" + xtend "^4.0.2" + streamx@^2.15.0, streamx@^2.18.0: version "2.18.0" resolved "https://registry.yarnpkg.com/streamx/-/streamx-2.18.0.tgz#5bc1a51eb412a667ebfdcd4e6cf6a6fc65721ac7" @@ -5662,13 +6307,20 @@ string-width@^5.0.1, string-width@^5.1.2: emoji-regex "^9.2.2" strip-ansi "^7.0.1" -string_decoder@^1.1.1: +string_decoder@^1.0.0, string_decoder@^1.1.1: version "1.3.0" resolved "https://registry.yarnpkg.com/string_decoder/-/string_decoder-1.3.0.tgz#42f114594a46cf1a8e30b0a84f56c78c3edac21e" integrity sha512-hkRX8U1WjJFd8LsDJ2yQ/wWWxaopEsABU1XfkM8A+j0+85JAGppt16cr1Whg6KIbb4okU6Mql6BOj+uup/wKeA== dependencies: safe-buffer "~5.2.0" +string_decoder@~1.1.1: + version "1.1.1" + resolved "https://registry.yarnpkg.com/string_decoder/-/string_decoder-1.1.1.tgz#9cf1611ba62685d7030ae9e4ba34149c3af03fc8" + integrity sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg== + dependencies: + safe-buffer "~5.1.0" + "strip-ansi-cjs@npm:strip-ansi@^6.0.1": version "6.0.1" resolved "https://registry.yarnpkg.com/strip-ansi/-/strip-ansi-6.0.1.tgz#9e26c63d30f53443e9489495b2105d37b67a85d9" @@ -5690,11 +6342,6 @@ strip-ansi@^7.0.1: dependencies: ansi-regex "^6.0.1" -strip-final-newline@^3.0.0: - version "3.0.0" - resolved "https://registry.yarnpkg.com/strip-final-newline/-/strip-final-newline-3.0.0.tgz#52894c313fbff318835280aed60ff71ebf12b8fd" - integrity sha512-dOESqjYr96iWYylGObzd39EuNTa5VJxyvVAEm5Jnh7KGo75V43Hk1odPQkNDyXNmUR6k+gEiDVXnjB8HJ3crXw== - strip-indent@^3.0.0: version "3.0.0" resolved "https://registry.yarnpkg.com/strip-indent/-/strip-indent-3.0.0.tgz#c32e1cee940b6b3432c771bc2c54bcce73cd3001" @@ -5750,6 +6397,26 @@ svelte-hmr@^0.16.0: resolved "https://registry.yarnpkg.com/svelte-hmr/-/svelte-hmr-0.16.0.tgz#9f345b7d1c1662f1613747ed7e82507e376c1716" integrity sha512-Gyc7cOS3VJzLlfj7wKS0ZnzDVdv3Pn2IuVeJPk9m2skfhcu5bq3wtIZyQGggr7/Iim5rH5cncyQft/kRLupcnA== +svelte@^4.2.19: + version "4.2.19" + resolved "https://registry.yarnpkg.com/svelte/-/svelte-4.2.19.tgz#4e6e84a8818e2cd04ae0255fcf395bc211e61d4c" + integrity sha512-IY1rnGr6izd10B0A8LqsBfmlT5OILVuZ7XsI0vdGPEvuonFV7NYEUK4dAkm9Zg2q0Um92kYjTpS1CAP3Nh/KWw== + dependencies: + "@ampproject/remapping" "^2.2.1" + "@jridgewell/sourcemap-codec" "^1.4.15" + "@jridgewell/trace-mapping" "^0.3.18" + "@types/estree" "^1.0.1" + acorn "^8.9.0" + aria-query "^5.3.0" + axobject-query "^4.0.0" + code-red "^1.0.3" + css-tree "^2.3.1" + estree-walker "^3.0.3" + is-reference "^3.0.1" + locate-character "^3.0.0" + magic-string "^0.30.4" + periscopic "^3.1.0" + symbol-tree@^3.2.4: version "3.2.4" resolved "https://registry.yarnpkg.com/symbol-tree/-/symbol-tree-3.2.4.tgz#430637d248ba77e078883951fb9aa0eed7c63fa2" @@ -5833,15 +6500,27 @@ through@^2.3.8: resolved "https://registry.yarnpkg.com/through/-/through-2.3.8.tgz#0dd4c9ffaabc357960b1b724115d7e0e86a2e1f5" integrity sha512-w89qg7PI8wAdvX60bMDP+bFoD5Dvhm9oLheFp5O4a2QF0cSBGsBX4qZmadPMvVqlLJBBci+WqGGOAPvcDeNSVg== +timers-browserify@^2.0.4: + version "2.0.12" + resolved "https://registry.yarnpkg.com/timers-browserify/-/timers-browserify-2.0.12.tgz#44a45c11fbf407f34f97bccd1577c652361b00ee" + integrity sha512-9phl76Cqm6FhSX9Xe1ZUAMLtm1BLkKj2Qd5ApyWkXzsMRaA7dgr81kf4wJmQf/hAvg8EEyJxDo3du/0KlhPiKQ== + dependencies: + setimmediate "^1.0.4" + tiny-typed-emitter@^2.1.0: version "2.1.0" resolved "https://registry.yarnpkg.com/tiny-typed-emitter/-/tiny-typed-emitter-2.1.0.tgz#b3b027fdd389ff81a152c8e847ee2f5be9fad7b5" integrity sha512-qVtvMxeXbVej0cQWKqVSSAHmKZEHAvxdF8HEUBFWts8h+xEo5m/lEiPakuyZ3BnCBjOD8i24kzNOiOLLgsSxhA== -tinybench@^2.8.0: - version "2.8.0" - resolved "https://registry.yarnpkg.com/tinybench/-/tinybench-2.8.0.tgz#30e19ae3a27508ee18273ffed9ac7018949acd7b" - integrity sha512-1/eK7zUnIklz4JUUlL+658n58XO2hHLQfSk1Zf2LKieUjxidN16eKFEoDEfjHc3ohofSSqK3X5yO6VGb6iW8Lw== +tinybench@^2.9.0: + version "2.9.0" + resolved "https://registry.yarnpkg.com/tinybench/-/tinybench-2.9.0.tgz#103c9f8ba6d7237a47ab6dd1dcff77251863426b" + integrity sha512-0+DUvqWMValLmha6lr4kD8iAMK1HzV0/aKnCtWb9v9641TnP/MFb7Pc2bxoxQjTXAErryXVgUOfv2YqNllqGeg== + +tinyexec@^0.3.0: + version "0.3.0" + resolved "https://registry.yarnpkg.com/tinyexec/-/tinyexec-0.3.0.tgz#ed60cfce19c17799d4a241e06b31b0ec2bee69e6" + integrity sha512-tVGE0mVJPGb0chKhqmsoosjsS+qUnJVGJpZgsHYQcGoPlG3B51R3PouqTgEGH2Dc9jjFyOqOpix6ZHNMXp1FZg== tinypool@^1.0.0: version "1.0.0" @@ -5916,11 +6595,21 @@ ts-api-utils@^1.3.0: resolved "https://registry.yarnpkg.com/ts-api-utils/-/ts-api-utils-1.3.0.tgz#4b490e27129f1e8e686b45cc4ab63714dc60eea1" integrity sha512-UQMIo7pb8WRomKR1/+MFVLTroIvDVtMX3K6OUir8ynLyzB8Jeriont2bTAtmNPa1ekAgN7YPDyf6V+ygrdU+eQ== +tsconfck@^3.0.3: + version "3.1.3" + resolved "https://registry.yarnpkg.com/tsconfck/-/tsconfck-3.1.3.tgz#a8202f51dab684c426314796cdb0bbd0fe0cdf80" + integrity sha512-ulNZP1SVpRDesxeMLON/LtWM8HIgAJEIVpVVhBM6gsmvQ8+Rh+ZG7FWGvHh7Ah3pRABwVJWklWCr/BTZSv0xnQ== + tslib@^2.0.1, tslib@^2.4.0: version "2.6.3" resolved "https://registry.yarnpkg.com/tslib/-/tslib-2.6.3.tgz#0438f810ad7a9edcde7a241c3d80db693c8cbfe0" integrity sha512-xNvxJEOUiWPGhUuUdQgAJPKOOJfGnIyKySOc09XkKsgdUV/3E2zvwZYdejjmRgPCgcym1juLH3226yA7sEFJKQ== +tty-browserify@0.0.1: + version "0.0.1" + resolved "https://registry.yarnpkg.com/tty-browserify/-/tty-browserify-0.0.1.tgz#3f05251ee17904dfd0677546670db9651682b811" + integrity sha512-C3TaO7K81YvjCgQH9Q1S3R3P3BtN3RIM8n+OvX4il1K1zgE8ZhI0op7kClgkxtutIE8hQrcrHBXvIheqKUUCxw== + tunnel-agent@^0.6.0: version "0.6.0" resolved "https://registry.yarnpkg.com/tunnel-agent/-/tunnel-agent-0.6.0.tgz#27a5dea06b36b04a0a9966774b290868f0fc40fd" @@ -6087,6 +6776,14 @@ url-template@^2.0.8: resolved "https://registry.yarnpkg.com/url-template/-/url-template-2.0.8.tgz#fc565a3cccbff7730c775f5641f9555791439f21" integrity sha512-XdVKMF4SJ0nP/O7XIPB0JwAEuT9lDIYnNsK8yGVe43y0AWoKeJNdv3ZNWh7ksJ6KqQFjOO6ox/VEitLnaVNufw== +url@^0.11.4: + version "0.11.4" + resolved "https://registry.yarnpkg.com/url/-/url-0.11.4.tgz#adca77b3562d56b72746e76b330b7f27b6721f3c" + integrity sha512-oCwdVC7mTuWiPyjLUz/COz5TLk6wgp0RCsN+wHZ2Ekneac9w8uuV0njcbbie2ME+Vs+d6duwmYuR3HgQXs1fOg== + dependencies: + punycode "^1.4.1" + qs "^6.12.3" + urlpattern-polyfill@10.0.0: version "10.0.0" resolved "https://registry.yarnpkg.com/urlpattern-polyfill/-/urlpattern-polyfill-10.0.0.tgz#f0a03a97bfb03cdf33553e5e79a2aadd22cac8ec" @@ -6102,11 +6799,22 @@ utf8-byte-length@^1.0.1: resolved "https://registry.yarnpkg.com/utf8-byte-length/-/utf8-byte-length-1.0.5.tgz#f9f63910d15536ee2b2d5dd4665389715eac5c1e" integrity sha512-Xn0w3MtiQ6zoz2vFyUVruaCL53O/DwUvkEeOvj+uulMm0BkUGYWmBYVyElqZaSLhY6ZD0ulfU3aBra2aVT4xfA== -util-deprecate@^1.0.1: +util-deprecate@^1.0.1, util-deprecate@~1.0.1: version "1.0.2" resolved "https://registry.yarnpkg.com/util-deprecate/-/util-deprecate-1.0.2.tgz#450d4dc9fa70de732762fbd2d4a28981419a0ccf" integrity sha512-EPD5q1uXyFxJpCrLnCc1nHnq3gOa6DZBocAIiI2TaSCA7VCJ1UJDMagCzIkXNsUYfD1daK//LTEQ8xiIbrHtcw== +util@^0.12.4, util@^0.12.5: + version "0.12.5" + resolved "https://registry.yarnpkg.com/util/-/util-0.12.5.tgz#5f17a6059b73db61a875668781a1c2b136bd6fbc" + integrity sha512-kZf/K6hEIrWHI6XqOFUiiMa+79wE/D8Q+NCNAWclkyg3b4d2k7s0QGepNjiABc+aR3N1PAyHL7p6UcLY6LmrnA== + dependencies: + inherits "^2.0.3" + is-arguments "^1.0.4" + is-generator-function "^1.0.7" + is-typed-array "^1.1.3" + which-typed-array "^1.1.2" + uuid@^8.3.2: version "8.3.2" resolved "https://registry.yarnpkg.com/uuid/-/uuid-8.3.2.tgz#80d5b5ced271bb9af6c445f21a1a04c606cefbe2" @@ -6126,17 +6834,33 @@ verror@^1.10.0: core-util-is "1.0.2" extsprintf "^1.2.0" -vite-node@2.0.5: - version "2.0.5" - resolved "https://registry.yarnpkg.com/vite-node/-/vite-node-2.0.5.tgz#36d909188fc6e3aba3da5fc095b3637d0d18e27b" - integrity sha512-LdsW4pxj0Ot69FAoXZ1yTnA9bjGohr2yNBU7QKRxpz8ITSkhuDl6h3zS/tvgz4qrNjeRnvrWeXQ8ZF7Um4W00Q== +vite-node@2.1.1: + version "2.1.1" + resolved "https://registry.yarnpkg.com/vite-node/-/vite-node-2.1.1.tgz#7d46f623c04dfed6df34e7127711508a3386fa1c" + integrity sha512-N/mGckI1suG/5wQI35XeR9rsMsPqKXzq1CdUndzVstBj/HvyxxGctwnK6WX43NGt5L3Z5tcRf83g4TITKJhPrA== dependencies: cac "^6.7.14" - debug "^4.3.5" + debug "^4.3.6" pathe "^1.1.2" - tinyrainbow "^1.2.0" vite "^5.0.0" +vite-plugin-node-polyfills@^0.22.0: + version "0.22.0" + resolved "https://registry.yarnpkg.com/vite-plugin-node-polyfills/-/vite-plugin-node-polyfills-0.22.0.tgz#d0afcf82eb985fc02244620d7cec1ddd1c6e0864" + integrity sha512-F+G3LjiGbG8QpbH9bZ//GSBr9i1InSTkaulfUHFa9jkLqVGORFBoqc2A/Yu5Mmh1kNAbiAeKeK+6aaQUf3x0JA== + dependencies: + "@rollup/plugin-inject" "^5.0.5" + node-stdlib-browser "^1.2.0" + +vite-tsconfig-paths@^5.0.1: + version "5.0.1" + resolved "https://registry.yarnpkg.com/vite-tsconfig-paths/-/vite-tsconfig-paths-5.0.1.tgz#c9387a29c32fd586e4c7f4e2b2da1f0b5c9a7403" + integrity sha512-yqwv+LstU7NwPeNqajZzLEBVpUFU6Dugtb2P84FXuvaoYA+/70l9MHE+GYfYAycVyPSDYZ7mjOFuYBRqlEpTig== + dependencies: + debug "^4.1.1" + globrex "^0.1.2" + tsconfck "^3.0.3" + vite@5.2.14, vite@^5.0.0: version "5.2.14" resolved "https://registry.yarnpkg.com/vite/-/vite-5.2.14.tgz#fd5f60facf6b5f90ec7da6323c467a365d380c3d" @@ -6153,31 +6877,36 @@ vitefu@^0.2.5: resolved "https://registry.yarnpkg.com/vitefu/-/vitefu-0.2.5.tgz#c1b93c377fbdd3e5ddd69840ea3aa70b40d90969" integrity sha512-SgHtMLoqaeeGnd2evZ849ZbACbnwQCIwRH57t18FxcXoZop0uQu0uzlIhJBlF/eWVzuce0sHeqPcDo+evVcg8Q== -vitest@^2.0.5: - version "2.0.5" - resolved "https://registry.yarnpkg.com/vitest/-/vitest-2.0.5.tgz#2f15a532704a7181528e399cc5b754c7f335fd62" - integrity sha512-8GUxONfauuIdeSl5f9GTgVEpg5BTOlplET4WEDaeY2QBiN8wSm68vxN/tb5z405OwppfoCavnwXafiaYBC/xOA== - dependencies: - "@ampproject/remapping" "^2.3.0" - "@vitest/expect" "2.0.5" - "@vitest/pretty-format" "^2.0.5" - "@vitest/runner" "2.0.5" - "@vitest/snapshot" "2.0.5" - "@vitest/spy" "2.0.5" - "@vitest/utils" "2.0.5" +vitest@^2.1.1: + version "2.1.1" + resolved "https://registry.yarnpkg.com/vitest/-/vitest-2.1.1.tgz#24a6f6f5d894509f10685b82de008c507faacbb1" + integrity sha512-97We7/VC0e9X5zBVkvt7SGQMGrRtn3KtySFQG5fpaMlS+l62eeXRQO633AYhSTC3z7IMebnPPNjGXVGNRFlxBA== + dependencies: + "@vitest/expect" "2.1.1" + "@vitest/mocker" "2.1.1" + "@vitest/pretty-format" "^2.1.1" + "@vitest/runner" "2.1.1" + "@vitest/snapshot" "2.1.1" + "@vitest/spy" "2.1.1" + "@vitest/utils" "2.1.1" chai "^5.1.1" - debug "^4.3.5" - execa "^8.0.1" - magic-string "^0.30.10" + debug "^4.3.6" + magic-string "^0.30.11" pathe "^1.1.2" std-env "^3.7.0" - tinybench "^2.8.0" + tinybench "^2.9.0" + tinyexec "^0.3.0" tinypool "^1.0.0" tinyrainbow "^1.2.0" vite "^5.0.0" - vite-node "2.0.5" + vite-node "2.1.1" why-is-node-running "^2.3.0" +vm-browserify@^1.0.1: + version "1.1.2" + resolved "https://registry.yarnpkg.com/vm-browserify/-/vm-browserify-1.1.2.tgz#78641c488b8e6ca91a75f511e7a3b32a86e5dda0" + integrity sha512-2ham8XPWTONajOR0ohOKOHXkm3+gaBmGut3SRuu75xLd/RRaY6vqgh8NBYYk7+RW3u5AtzPQZG8F10LHkl0lAQ== + w3c-xmlserializer@^5.0.0: version "5.0.0" resolved "https://registry.yarnpkg.com/w3c-xmlserializer/-/w3c-xmlserializer-5.0.0.tgz#f925ba26855158594d907313cedd1476c5967f6c" @@ -6250,6 +6979,17 @@ whatwg-url@^5.0.0: tr46 "~0.0.3" webidl-conversions "^3.0.0" +which-typed-array@^1.1.14, which-typed-array@^1.1.2: + version "1.1.15" + resolved "https://registry.yarnpkg.com/which-typed-array/-/which-typed-array-1.1.15.tgz#264859e9b11a649b388bfaaf4f767df1f779b38d" + integrity sha512-oV0jmFtUky6CXfkqehVvBP/LSWJ2sy4vWMioiENyJLePrBO/yKyV9OyJySfAKosh+RYkIl5zJCNZ8/4JncrpdA== + dependencies: + available-typed-arrays "^1.0.7" + call-bind "^1.0.7" + for-each "^0.3.3" + gopd "^1.0.1" + has-tostringtag "^1.0.2" + which@^2.0.1: version "2.0.2" resolved "https://registry.yarnpkg.com/which/-/which-2.0.2.tgz#7c6a8dd0a636a0327e10b59c9286eee93f3f51b1" @@ -6332,7 +7072,7 @@ xmlchars@^2.2.0: resolved "https://registry.yarnpkg.com/xmlchars/-/xmlchars-2.2.0.tgz#060fe1bcb7f9c76fe2a17db86a9bc3ab894210cb" integrity sha512-JZnDKK8B0RCDw84FNdDAIpZK+JuJw+s7Lz8nksI7SIuU3UXJJslUthsi+uWBUYOwPFwW7W7PRLRfUKpxjtjFCw== -xtend@^4.0.0: +xtend@^4.0.0, xtend@^4.0.2: version "4.0.2" resolved "https://registry.yarnpkg.com/xtend/-/xtend-4.0.2.tgz#bb72779f5fa465186b1f438f674fa347fdb5db54" integrity sha512-LKYU1iAXJXUgAXn9URjiu+MWhyUXHsvfp7mcuYm9dSUKK0/CjtrUwFAxD82/mCWbtLsGjFIad0wIsod4zrTAEQ== From df360d0f64c63939b114a95d7b821aa156a48c24 Mon Sep 17 00:00:00 2001 From: "shai.ungar" Date: Sat, 21 Sep 2024 19:27:59 +0300 Subject: [PATCH 02/16] fix --- packages/renderer/vitest-setup.js | 44 ++++++++++++++++++++++++------- vitest-setup.js | 25 ------------------ 2 files changed, 34 insertions(+), 35 deletions(-) diff --git a/packages/renderer/vitest-setup.js b/packages/renderer/vitest-setup.js index edc677f1..8412dc7e 100644 --- a/packages/renderer/vitest-setup.js +++ b/packages/renderer/vitest-setup.js @@ -1,16 +1,40 @@ import { vi } from 'vitest'; -vi.mock('electron', () => ({ - default: { - ipcRenderer: { - invoke: vi.fn(), - send: vi.fn(), - }, - shell: { - openExternal: vi.fn(), +Object.defineProperty(window, 'matchMedia', { + writable: true, + value: vi.fn().mockImplementation((query) => ({ + matches: false, // You can set this to true if you want to simulate a matching media query + media: query, + onchange: null, + addListener: vi.fn(), // Deprecated method + removeListener: vi.fn(), // Deprecated method + addEventListener: vi.fn(), + removeEventListener: vi.fn(), + dispatchEvent: vi.fn(), + })), +}); + +vi.mock('electron', () => { + const invokeSpy = vi.fn((channel) => { + if (channel === 'getAppInfo') { + return Promise.resolve({ name: 'Test App', version: '1.0.0' }); + } + if (channel === 'getConfig') { + return Promise.resolve(JSON.stringify({ config: { someKey: 'someValue' } })); + } + if (channel === 'getLogsInfo') { + return Promise.resolve({ logsFolder: '/path/to/logs', otherData: 'someValue' }); // Ensure logsFolder is defined + } + return Promise.resolve(null); + }); + return { + default: { + ipcRenderer: { + invoke: invokeSpy, + }, }, - }, -})); + }; +}); global.window.require = vi.fn().mockImplementation((module) => { if (module === 'electron') { diff --git a/vitest-setup.js b/vitest-setup.js index 225f2963..bb02c60c 100644 --- a/vitest-setup.js +++ b/vitest-setup.js @@ -1,26 +1 @@ import '@testing-library/jest-dom/vitest'; -import { vi } from 'vitest'; - -vi.mock('electron', () => ({ - ipcRenderer: { - invoke: vi.fn(), - send: vi.fn(), - }, - shell: { - openExternal: vi.fn(), - }, -})); - -global.window.require = vi.fn().mockImplementation((module) => { - if (module === 'electron') { - return { - ipcRenderer: { - invoke: vi.fn(), - send: vi.fn(), - }, - shell: { - openExternal: vi.fn(), - }, - }; - } -}); From f0903cf442a73e67fafd4cf94e9fe4bfb1dd1517 Mon Sep 17 00:00:00 2001 From: "shai.ungar" Date: Sat, 21 Sep 2024 19:32:58 +0300 Subject: [PATCH 03/16] fix import --- vitest.config.js | 11 ++--------- 1 file changed, 2 insertions(+), 9 deletions(-) diff --git a/vitest.config.js b/vitest.config.js index e2c8a90a..3b3aa6b3 100644 --- a/vitest.config.js +++ b/vitest.config.js @@ -2,24 +2,17 @@ import { svelte } from '@sveltejs/vite-plugin-svelte'; import { svelteTesting } from '@testing-library/svelte/vite'; import { defineConfig } from 'vitest/config'; import tsconfigPaths from 'vite-tsconfig-paths'; -import baseConfig from 'vitest.base.config.js'; +import baseConfig from './vitest.base.config.js'; export default defineConfig({ - ...baseConfig, plugins: [svelte(), svelteTesting(), tsconfigPaths()], test: { - environment: 'jsdom', + ...baseConfig.test, setupFiles: './vitest-setup.js', /** * By default, vitest searches for the test files in all packages. * For e2e tests, have vitest search only in the project root 'tests' folder. */ include: ['./tests/**/*.{test,spec}.{js,mjs,cjs,ts,mts,cts,jsx,tsx}'], - - /** - * The default timeout of 5000ms is sometimes not enough for playwright. - */ - testTimeout: 30_000, - hookTimeout: 30_000, }, }); From 58c2f9b608acaef87fae5ad1917d204e624241b1 Mon Sep 17 00:00:00 2001 From: "shai.ungar" Date: Sat, 21 Sep 2024 21:57:01 +0300 Subject: [PATCH 04/16] remove tests --- packages/preload/src/commonTypes.ts | 2 -- tests/e2e.spec.ts | 53 ----------------------------- 2 files changed, 55 deletions(-) diff --git a/packages/preload/src/commonTypes.ts b/packages/preload/src/commonTypes.ts index b96ea91a..44c85186 100644 --- a/packages/preload/src/commonTypes.ts +++ b/packages/preload/src/commonTypes.ts @@ -66,7 +66,6 @@ export interface JsonConfig extends OutputVendorConfigBase { export interface GoogleSheetsConfig extends OutputVendorConfigBase { options: { credentials: Credentials; - // credentials: string; spreadsheetId: string; }; } @@ -82,7 +81,6 @@ export interface YnabConfig extends OutputVendorConfigBase { export interface AccountToScrapeConfig { id: string; - // key: CompanyTypes; key: string; name: string; loginFields: Record; diff --git a/tests/e2e.spec.ts b/tests/e2e.spec.ts index 07bbba40..629db2ae 100644 --- a/tests/e2e.spec.ts +++ b/tests/e2e.spec.ts @@ -18,11 +18,8 @@ afterAll(async () => { }); test('Main window state', async () => { - console.log('start'); const page = await electronApp.firstWindow(); - console.log('await electronApp.firstWindow'); const window: JSHandle = await electronApp.browserWindow(page); - console.log('await electronApp.browserWindow(page)'); const windowState = await window.evaluate( ( mainWindow, @@ -49,8 +46,6 @@ test('Main window state', async () => { }, ); - console.log('await window.evaluate'); - expect(windowState.isCrashed, 'The app has crashed').toBeFalsy(); expect(windowState.isVisible, 'The main window was not visible').toBeTruthy(); expect( @@ -68,51 +63,3 @@ test('Main window web content', async () => { 'Window content was empty', ).not.equal(''); }); - -test('Preload versions', async () => { - const page = await electronApp.firstWindow(); - const versionsElement = page.locator('#process-versions'); - expect( - await versionsElement.count(), - 'expect find one element #process-versions', - ).toStrictEqual(1); - - /** - * In this test we check only text value and don't care about formatting. That's why here we remove any space symbols - */ - const renderedVersions = (await versionsElement.innerText()).replace( - /\s/g, - '', - ); - const expectedVersions = await electronApp.evaluate(() => process.versions); - - for (const expectedVersionsKey in expectedVersions) { - expect(renderedVersions).include( - `${expectedVersionsKey}:v${expectedVersions[expectedVersionsKey]}`, - ); - } -}); - -test('Preload nodeCrypto', async () => { - const page = await electronApp.firstWindow(); - - // Test hashing a random string - const testString = Math.random().toString(36).slice(2, 7); - - const rawInput = page.locator('input#reactive-hash-raw-value'); - expect( - await rawInput.count(), - 'expect find one element input#reactive-hash-raw-value', - ).toStrictEqual(1); - - const hashedInput = page.locator('input#reactive-hash-hashed-value'); - expect( - await hashedInput.count(), - 'expect find one element input#reactive-hash-hashed-value', - ).toStrictEqual(1); - - await rawInput.fill(testString); - const renderedHash = await hashedInput.inputValue(); - const expectedHash = createHash('sha256').update(testString).digest('hex'); - expect(renderedHash).toEqual(expectedHash); -}); From 0a4df65c536c127e3cf891e28fe4a3b8c13632d1 Mon Sep 17 00:00:00 2001 From: "shai.ungar" Date: Sat, 21 Sep 2024 22:07:57 +0300 Subject: [PATCH 05/16] remove unused import --- tests/e2e.spec.ts | 1 - 1 file changed, 1 deletion(-) diff --git a/tests/e2e.spec.ts b/tests/e2e.spec.ts index 629db2ae..13c887ac 100644 --- a/tests/e2e.spec.ts +++ b/tests/e2e.spec.ts @@ -1,4 +1,3 @@ -import { createHash } from 'crypto'; import { type BrowserWindow } from 'electron'; import { _electron as electron, From d84d485d99770859bad1e76d44a3be2b124a2887 Mon Sep 17 00:00:00 2001 From: "shai.ungar" Date: Sat, 21 Sep 2024 22:22:11 +0300 Subject: [PATCH 06/16] format check --- packages/renderer/src/store/ConfigStore.tsx | 3 ++- packages/renderer/src/store/Store.test.tsx | 7 +++++-- packages/renderer/vitest-setup.js | 9 +++++++-- vitest.base.config.js | 2 +- 4 files changed, 15 insertions(+), 6 deletions(-) diff --git a/packages/renderer/src/store/ConfigStore.tsx b/packages/renderer/src/store/ConfigStore.tsx index cf32f058..8036754b 100644 --- a/packages/renderer/src/store/ConfigStore.tsx +++ b/packages/renderer/src/store/ConfigStore.tsx @@ -14,7 +14,8 @@ import { type Exporter, type Importer, type Log, - type OutputVendorName, DownalodChromeEvent, + type OutputVendorName, + DownalodChromeEvent, } from '../types'; interface AccountScrapingData { diff --git a/packages/renderer/src/store/Store.test.tsx b/packages/renderer/src/store/Store.test.tsx index 335ae79a..7bd8eee6 100644 --- a/packages/renderer/src/store/Store.test.tsx +++ b/packages/renderer/src/store/Store.test.tsx @@ -2,7 +2,8 @@ import { configStore } from './ConfigStore'; import { AccountType, CompanyTypes, - type Config, Credentials, + type Config, + Credentials, type Exporter, type Importer, } from '../types'; @@ -34,7 +35,9 @@ describe('Store', () => { const visaCalImporter = store.importers.find( (i: Importer) => i.companyId === 'visaCal', ); - const maxImporter = store.importers.find((i: Importer) => i.companyId === 'max'); + const maxImporter = store.importers.find( + (i: Importer) => i.companyId === 'max', + ); expect(discountImporter).toMatchSnapshot(); expect(visaCalImporter).toMatchSnapshot(); diff --git a/packages/renderer/vitest-setup.js b/packages/renderer/vitest-setup.js index 8412dc7e..45560e34 100644 --- a/packages/renderer/vitest-setup.js +++ b/packages/renderer/vitest-setup.js @@ -20,10 +20,15 @@ vi.mock('electron', () => { return Promise.resolve({ name: 'Test App', version: '1.0.0' }); } if (channel === 'getConfig') { - return Promise.resolve(JSON.stringify({ config: { someKey: 'someValue' } })); + return Promise.resolve( + JSON.stringify({ config: { someKey: 'someValue' } }), + ); } if (channel === 'getLogsInfo') { - return Promise.resolve({ logsFolder: '/path/to/logs', otherData: 'someValue' }); // Ensure logsFolder is defined + return Promise.resolve({ + logsFolder: '/path/to/logs', + otherData: 'someValue', + }); } return Promise.resolve(null); }); diff --git a/vitest.base.config.js b/vitest.base.config.js index f04414cb..f9491a35 100644 --- a/vitest.base.config.js +++ b/vitest.base.config.js @@ -4,4 +4,4 @@ export default { testTimeout: 30_000, hookTimeout: 30_000, }, -}; \ No newline at end of file +}; From df0f361c20eb745113e9f24d38fac5e461e4ee8c Mon Sep 17 00:00:00 2001 From: "shai.ungar" Date: Sat, 21 Sep 2024 22:29:58 +0300 Subject: [PATCH 07/16] lint --- package.json | 1 + packages/renderer/src/store/ConfigStore.tsx | 2 +- packages/renderer/src/store/Store.test.tsx | 2 +- 3 files changed, 3 insertions(+), 2 deletions(-) diff --git a/package.json b/package.json index ac3d4c6b..02b6d5f3 100644 --- a/package.json +++ b/package.json @@ -22,6 +22,7 @@ "test:renderer": "vitest run -r packages/renderer --passWithNoTests", "watch": "node scripts/watch.js", "lint": "eslint . --ext js,mjs,cjs,ts,mts,cts,tsx", + "lint:fix": "eslint . --fix --ext js,mjs,cjs,ts,mts,cts,tsx", "typecheck:main": "tsc --noEmit -p packages/main/tsconfig.json", "typecheck:preload": "tsc --noEmit -p packages/preload/tsconfig.json", "typecheck:renderer": "tsc --noEmit -p packages/renderer/tsconfig.json", diff --git a/packages/renderer/src/store/ConfigStore.tsx b/packages/renderer/src/store/ConfigStore.tsx index 8036754b..deb59349 100644 --- a/packages/renderer/src/store/ConfigStore.tsx +++ b/packages/renderer/src/store/ConfigStore.tsx @@ -15,7 +15,7 @@ import { type Importer, type Log, type OutputVendorName, - DownalodChromeEvent, + type DownalodChromeEvent, } from '../types'; interface AccountScrapingData { diff --git a/packages/renderer/src/store/Store.test.tsx b/packages/renderer/src/store/Store.test.tsx index 7bd8eee6..1b17e2bb 100644 --- a/packages/renderer/src/store/Store.test.tsx +++ b/packages/renderer/src/store/Store.test.tsx @@ -3,7 +3,7 @@ import { AccountType, CompanyTypes, type Config, - Credentials, + type Credentials, type Exporter, type Importer, } from '../types'; From 79e906701586f03fe1ca0a03a83128328707968f Mon Sep 17 00:00:00 2001 From: "shai.ungar" Date: Sat, 21 Sep 2024 22:54:13 +0300 Subject: [PATCH 08/16] lint --- packages/renderer/.eslintrc.json | 2 +- .../components/exporters/EditYnabExporter.tsx | 24 ++++++++++--------- packages/renderer/src/store/ConfigStore.tsx | 2 +- packages/renderer/src/store/Store.test.tsx | 4 ++-- packages/renderer/vitest-setup.js | 14 ----------- 5 files changed, 17 insertions(+), 29 deletions(-) diff --git a/packages/renderer/.eslintrc.json b/packages/renderer/.eslintrc.json index 23da699a..76542459 100644 --- a/packages/renderer/.eslintrc.json +++ b/packages/renderer/.eslintrc.json @@ -1,7 +1,7 @@ { "env": { "browser": true, - "node": false + "node": true }, "extends": ["plugin:react-hooks/recommended"], "parserOptions": { diff --git a/packages/renderer/src/components/exporters/EditYnabExporter.tsx b/packages/renderer/src/components/exporters/EditYnabExporter.tsx index f6afc7e4..3e8261da 100644 --- a/packages/renderer/src/components/exporters/EditYnabExporter.tsx +++ b/packages/renderer/src/components/exporters/EditYnabExporter.tsx @@ -1,6 +1,6 @@ import { toJS } from 'mobx'; import { observer } from 'mobx-react-lite'; -import { useEffect, useState } from 'react'; +import { useCallback, useEffect, useState } from 'react'; import { Button, Card, Form, Image } from 'react-bootstrap'; import Spinner from 'react-bootstrap/Spinner'; import { type YnabConfig } from '../../types'; @@ -37,22 +37,24 @@ const EditYnabExporter = ({ if (!ynabOptions.budgetId && defaultBudgetId) { updateOptionsState({ budgetId: defaultBudgetId }); } - }, [store.ynabAccountData, ynabOptions.budgetId]); + }, [store.ynabAccountData, ynabOptions.budgetId, updateOptionsState]); useEffect(() => { if (ynabOptions.accessToken) { store.fetchYnabAccountData(ynabOptions); } - }, [ynabOptions.budgetId, ynabOptions.accessToken, store]); + }, [ynabOptions, store]); + + const updateOptionsState = useCallback( + (optionUpdates: Partial) => { + setYnabOptions((prevYnabOptions) => ({ + ...prevYnabOptions, + ...optionUpdates, + })); + }, + [], + ); - const updateOptionsState = ( - optionUpdates: Partial, - ) => { - setYnabOptions({ - ...ynabOptions, - ...optionUpdates, - }); - }; const handleSaveClick = async () => { await handleSave({ ...exporterConfig, diff --git a/packages/renderer/src/store/ConfigStore.tsx b/packages/renderer/src/store/ConfigStore.tsx index deb59349..572cbd04 100644 --- a/packages/renderer/src/store/ConfigStore.tsx +++ b/packages/renderer/src/store/ConfigStore.tsx @@ -69,7 +69,7 @@ const saveConfigIntoFile = (config?: Config) => { updateConfig(toJS(config)); }; -class ConfigStore { +export class ConfigStore { config: Config; chromeDownloadPercent = 0; diff --git a/packages/renderer/src/store/Store.test.tsx b/packages/renderer/src/store/Store.test.tsx index 1b17e2bb..448ab4b4 100644 --- a/packages/renderer/src/store/Store.test.tsx +++ b/packages/renderer/src/store/Store.test.tsx @@ -1,4 +1,4 @@ -import { configStore } from './ConfigStore'; +import { type ConfigStore, configStore } from './ConfigStore'; import { AccountType, CompanyTypes, @@ -10,7 +10,7 @@ import { import { beforeEach, describe, test, expect } from 'vitest'; describe('Store', () => { - let store: any; + let store: ConfigStore; beforeEach(() => { store = configStore; store.config = dummyConfig; diff --git a/packages/renderer/vitest-setup.js b/packages/renderer/vitest-setup.js index 45560e34..049b222d 100644 --- a/packages/renderer/vitest-setup.js +++ b/packages/renderer/vitest-setup.js @@ -41,18 +41,4 @@ vi.mock('electron', () => { }; }); -global.window.require = vi.fn().mockImplementation((module) => { - if (module === 'electron') { - return { - ipcRenderer: { - invoke: vi.fn(), - send: vi.fn(), - }, - shell: { - openExternal: vi.fn(), - }, - }; - } -}); - import '@testing-library/jest-dom/vitest'; From 49264750ac48a0e810b9d1d44d20c13181a48cc4 Mon Sep 17 00:00:00 2001 From: "shai.ungar" Date: Sat, 21 Sep 2024 23:12:09 +0300 Subject: [PATCH 09/16] We do not accept nodejs code on renderer in this new Vite structure --- packages/renderer/.eslintrc.json | 2 +- packages/renderer/vitest.config.js | 5 +++++ 2 files changed, 6 insertions(+), 1 deletion(-) diff --git a/packages/renderer/.eslintrc.json b/packages/renderer/.eslintrc.json index 76542459..23da699a 100644 --- a/packages/renderer/.eslintrc.json +++ b/packages/renderer/.eslintrc.json @@ -1,7 +1,7 @@ { "env": { "browser": true, - "node": true + "node": false }, "extends": ["plugin:react-hooks/recommended"], "parserOptions": { diff --git a/packages/renderer/vitest.config.js b/packages/renderer/vitest.config.js index 7a69b104..8a0931c2 100644 --- a/packages/renderer/vitest.config.js +++ b/packages/renderer/vitest.config.js @@ -2,6 +2,11 @@ import { defineConfig } from 'vitest/config'; import tsconfigPaths from 'vite-tsconfig-paths'; import baseConfig from '../../vitest.base.config.js'; import path from 'path'; +import { fileURLToPath } from 'node:url'; +import { dirname } from 'node:path'; + +const __filename = fileURLToPath(import.meta.url); +const __dirname = dirname(__filename); export default defineConfig({ ...baseConfig, From a77b795a96c85a938428fa2b2284c7c7c6dab455 Mon Sep 17 00:00:00 2001 From: "shai.ungar" Date: Thu, 26 Sep 2024 11:54:55 +0300 Subject: [PATCH 10/16] typecheck --- .eslintrc.cjs | 2 +- package.json | 3 ++- packages/renderer/src/accountMetadata.tsx | 4 ++-- packages/renderer/src/components/Body.tsx | 15 +++++------- .../src/components/GeneralSettings.tsx | 8 +++---- .../components/accounts/CreateImporter.tsx | 6 ++--- .../src/components/accounts/EditImporter.tsx | 16 +++++++------ .../src/components/accounts/Importers.tsx | 3 ++- .../src/components/exporters/EditExporter.tsx | 8 +++---- .../components/exporters/EditFileExporter.tsx | 4 ++-- .../components/exporters/EditYnabExporter.tsx | 23 +++++++++---------- .../exporters/YnabAccountMappingTable.tsx | 8 ++++--- .../google-sheets/EditSheetsExporter.tsx | 4 ++-- .../exporters/google-sheets/LoginButton.tsx | 2 +- .../google-sheets/SheetsDropdown.tsx | 13 +++++++---- .../components/topBar/ReportProblemModal.tsx | 14 +++++------ .../renderer/src/components/topBar/TopBar.tsx | 6 ++--- .../src/react-bootstrap-table2-editor.d.ts | 1 + packages/renderer/src/reportWebVitals.ts | 18 +++++++-------- packages/renderer/src/store/AppInfoStore.tsx | 2 +- packages/renderer/src/store/ConfigStore.tsx | 8 ++++--- packages/renderer/src/types.tsx | 2 +- yarn.lock | 15 ++++++++---- 23 files changed, 100 insertions(+), 85 deletions(-) create mode 100644 packages/renderer/src/react-bootstrap-table2-editor.d.ts diff --git a/.eslintrc.cjs b/.eslintrc.cjs index afff23f8..9e8a4ca5 100644 --- a/.eslintrc.cjs +++ b/.eslintrc.cjs @@ -16,7 +16,7 @@ module.exports = { parserOptions: { ecmaVersion: 12, sourceType: 'module', - project: './tsconfig.test.json', + project: './tsconfig.json', }, plugins: ['@typescript-eslint'], ignorePatterns: ['node_modules/**', '**/dist/**'], diff --git a/package.json b/package.json index 02b6d5f3..a00cb25e 100644 --- a/package.json +++ b/package.json @@ -42,6 +42,7 @@ "@types/lodash": "^4.17.4", "@types/node": "20.14.1", "@types/react": "^18.3.3", + "@types/react-bootstrap-table-next": "^4.0.26", "@types/react-dom": "^18.3.0", "@types/uuid": "^10.0.0", "@typescript-eslint/eslint-plugin": "7.12.0", @@ -96,7 +97,7 @@ "react-dom": "^18.3.1", "svelte": "^4.2.19", "vite-plugin-node-polyfills": "^0.22.0", - "web-vitals": "^4.2.0", + "web-vitals": "^4.2.3", "ynab": "^1.19.0" } } diff --git a/packages/renderer/src/accountMetadata.tsx b/packages/renderer/src/accountMetadata.tsx index 1979899a..957a9655 100644 --- a/packages/renderer/src/accountMetadata.tsx +++ b/packages/renderer/src/accountMetadata.tsx @@ -52,7 +52,7 @@ const accountMetadata: Record< return { companyId: accountId, companyName: displayName, - logo: icons[accountId], + logo: icons[accountId as CompanyTypes | OutputVendorName], }; }); @@ -111,7 +111,7 @@ export const importers: Account[] = Object.values(CompanyTypes).map( const importer: Account = { id: importerName, - companyId, + companyId: companyId as CompanyTypes | OutputVendorName, displayName: companyName, logo, type: AccountType.IMPORTER, diff --git a/packages/renderer/src/components/Body.tsx b/packages/renderer/src/components/Body.tsx index dba11709..e316d29e 100644 --- a/packages/renderer/src/components/Body.tsx +++ b/packages/renderer/src/components/Body.tsx @@ -7,9 +7,10 @@ import { useConfigStore } from '../store/ConfigStore'; import { ModalStatus, OutputVendorName, + YnabConfig, type Account, type Exporter, - type Importer, + type Importer, GoogleSheetsConfig, } from '../types'; import styles from './Body.module.css'; import CheckForUpdates from './CheckForUpdates'; @@ -84,9 +85,6 @@ const Body = () => { {configStore.config?.outputVendors && ( { currentAccount && ( )} {modalStatus === ModalStatus.EXPORTER_SETTINGS && currentAccount && ( Promise} + exporter={currentAccount as Exporter} /> )} {modalStatus === ModalStatus.NEW_SCRAPER && ( @@ -147,7 +144,7 @@ const Body = () => { showModal(null, ModalStatus.GENERAL_SETTINGS)} + onClick={() => showModal({} as Account, ModalStatus.GENERAL_SETTINGS)} className={styles.pointer} /> diff --git a/packages/renderer/src/components/GeneralSettings.tsx b/packages/renderer/src/components/GeneralSettings.tsx index 46cf72ff..6a5bf899 100644 --- a/packages/renderer/src/components/GeneralSettings.tsx +++ b/packages/renderer/src/components/GeneralSettings.tsx @@ -34,7 +34,7 @@ function GeneralSettings() { className={styles.input} defaultValue={configStore.config?.scraping.numDaysBack} onBlur={(event) => - configStore.setNumDaysBack(event.target.value) + configStore.setNumDaysBack(Number(event.target.value)) } autoFocus /> @@ -45,7 +45,7 @@ function GeneralSettings() { className={styles.input} defaultValue={configStore.config?.scraping.maxConcurrency} onBlur={(event) => - configStore.setMaxConcurrency(event.target.value) + configStore.setMaxConcurrency(Number(event.target.value)) } /> @@ -60,7 +60,7 @@ function GeneralSettings() { /> - כמה זמן לחכות לשליפה? (millisec) + כמה זמן לחכות לשליפה? (millisecond) (); - const handleChooseImporter = (importer: Importer) => - setImporterToCreate({ ...importer, id: uuidv4() }); + const handleChooseImporter = (importer: AccountType) => + setImporterToCreate({ ...importer, id: uuidv4(), loginFields: {} }); return (
{importerToCreate ? ( diff --git a/packages/renderer/src/components/accounts/EditImporter.tsx b/packages/renderer/src/components/accounts/EditImporter.tsx index dcaa87fb..2b26c0c8 100644 --- a/packages/renderer/src/components/accounts/EditImporter.tsx +++ b/packages/renderer/src/components/accounts/EditImporter.tsx @@ -32,19 +32,19 @@ export default function EditImporter({ }); }; - const checkFieldValidity = (loginFieldName: string, value): boolean => { + const checkFieldValidity = (loginFieldName: keyof typeof LOGIN_FIELD_MIN_LENGTH, value: string): boolean => { return value.length >= LOGIN_FIELD_MIN_LENGTH[loginFieldName]; }; - const checkFieldsValidity = (fieldsToCheck) => { + const checkFieldsValidity = (fieldsToCheck: Record) => { setValidated( Object.entries(fieldsToCheck).every(([key, value]) => - checkFieldValidity(key, value), + checkFieldValidity(key as keyof typeof LOGIN_FIELD_MIN_LENGTH, value), ), ); }; - const onLoginFieldChanged = (loginFieldName: string, loginFieldValue) => { + const onLoginFieldChanged = (loginFieldName: string, loginFieldValue: string) => { setLoginFields((prevLoginFields) => { const nextLoginFields = { ...prevLoginFields, @@ -74,15 +74,17 @@ export default function EditImporter({ />
- {IMPORTERS_LOGIN_FIELDS[importer.companyId].map( - (loginField, index) => ( + {IMPORTERS_LOGIN_FIELDS[ + importer.companyId as keyof typeof IMPORTERS_LOGIN_FIELDS + ].map( + (loginField: string, index: number) => ( diff --git a/packages/renderer/src/components/accounts/Importers.tsx b/packages/renderer/src/components/accounts/Importers.tsx index b2e6e241..f938f76e 100644 --- a/packages/renderer/src/components/accounts/Importers.tsx +++ b/packages/renderer/src/components/accounts/Importers.tsx @@ -4,6 +4,7 @@ import resultsIcon from '../../assets/results.svg'; import { AccountStatus, ModalStatus, + OutputVendorName, AccountType as TypeOfAccount, type Account as AccountType, } from '../../types'; @@ -37,7 +38,7 @@ function Importers({ account, isScraping, () => { - configStore.openResults(account.companyId); + configStore.openResults(account.companyId as OutputVendorName); }, )} /> diff --git a/packages/renderer/src/components/exporters/EditExporter.tsx b/packages/renderer/src/components/exporters/EditExporter.tsx index 85c6ef3c..6d93c0f6 100644 --- a/packages/renderer/src/components/exporters/EditExporter.tsx +++ b/packages/renderer/src/components/exporters/EditExporter.tsx @@ -1,10 +1,10 @@ -import { OutputVendorName, type Exporter, type YnabConfig } from '../../types'; +import { OutputVendorName, type Exporter, type YnabConfig, type GoogleSheetsConfig } from '../../types'; import EditFileExporter from './EditFileExporter'; import EditYnabExporter from './EditYnabExporter'; import EditSheetsExporter from './google-sheets/EditSheetsExporter'; interface EditExporterProps { - handleSave: (exporterConfig: Exporter | YnabConfig) => Promise; + handleSave: (exporterConfig: Exporter | YnabConfig | GoogleSheetsConfig) => Promise; exporter: Exporter; } @@ -23,11 +23,11 @@ export default function EditExporter({ ); exporterTypeToEditComponent.set( OutputVendorName.YNAB, - , + , ); exporterTypeToEditComponent.set( OutputVendorName.GOOGLE_SHEETS, - , + , ); return <>{exporterTypeToEditComponent.get(exporter.companyId)}; } diff --git a/packages/renderer/src/components/exporters/EditFileExporter.tsx b/packages/renderer/src/components/exporters/EditFileExporter.tsx index cc997056..a194944e 100644 --- a/packages/renderer/src/components/exporters/EditFileExporter.tsx +++ b/packages/renderer/src/components/exporters/EditFileExporter.tsx @@ -2,7 +2,7 @@ import { showSaveDialog } from '#preload'; import { observer } from 'mobx-react-lite'; import React, { useState } from 'react'; import { Button, Card, Form, Image } from 'react-bootstrap'; -import { type Exporter } from '/@/types'; +import type { CsvConfig, Exporter, JsonConfig } from '/@/types'; import styles from './EditFileExporter.module.css'; interface EditFileExporterProps { @@ -63,7 +63,7 @@ const EditFileExporter = ({ handleSave, exporter }: EditFileExporterProps) => { לאיזה קובץ לכתוב את הטרנזאקציות? diff --git a/packages/renderer/src/components/exporters/EditYnabExporter.tsx b/packages/renderer/src/components/exporters/EditYnabExporter.tsx index 3e8261da..6dd27470 100644 --- a/packages/renderer/src/components/exporters/EditYnabExporter.tsx +++ b/packages/renderer/src/components/exporters/EditYnabExporter.tsx @@ -30,6 +30,16 @@ const EditYnabExporter = ({ const isValidAccessToken = !isLoading && store.ynabAccountData?.status !== INVALID_ACCESS_TOKEN; + const updateOptionsState = useCallback( + (optionUpdates: Partial) => { + setYnabOptions((prevYnabOptions) => ({ + ...prevYnabOptions, + ...optionUpdates, + })); + }, + [], + ); + // Set default budget id if not set useEffect(() => { const defaultBudgetId = @@ -45,16 +55,6 @@ const EditYnabExporter = ({ } }, [ynabOptions, store]); - const updateOptionsState = useCallback( - (optionUpdates: Partial) => { - setYnabOptions((prevYnabOptions) => ({ - ...prevYnabOptions, - ...optionUpdates, - })); - }, - [], - ); - const handleSaveClick = async () => { await handleSave({ ...exporterConfig, @@ -65,7 +65,7 @@ const EditYnabExporter = ({ const handleOptionChangeEvent = ( propertyName: keyof YnabConfig['options'], - event: React.ChangeEvent, + event: React.ChangeEvent, ) => { updateOptionsState({ [propertyName]: event.target.value }); }; @@ -83,7 +83,6 @@ const EditYnabExporter = ({ { mappingObject[accountNumber] = ynabAccountId; }); diff --git a/packages/renderer/src/components/exporters/google-sheets/EditSheetsExporter.tsx b/packages/renderer/src/components/exporters/google-sheets/EditSheetsExporter.tsx index b684469c..dc8647ae 100644 --- a/packages/renderer/src/components/exporters/google-sheets/EditSheetsExporter.tsx +++ b/packages/renderer/src/components/exporters/google-sheets/EditSheetsExporter.tsx @@ -7,6 +7,7 @@ import styles from '../EditFileExporter.module.css'; import LoginButton from './LoginButton'; import SheetsDropdown from './SheetsDropdown'; import { Status, createSheetIfNew, useTokenStatus } from './hooks'; +import type { Auth } from 'googleapis'; interface EditSheetsExporterProps { handleSave: (exporterConfig: GoogleSheetsConfig) => Promise; @@ -59,7 +60,7 @@ const EditSheetsExporter: React.FC = ({ } if (loginStatus === Status.LOGIN) { - const updateCredentials = (credentials: Credentials) => { + const updateCredentials = (credentials: Auth.Credentials) => { setSheetsConfig((prev) => ({ ...prev, options: { @@ -76,7 +77,6 @@ const EditSheetsExporter: React.FC = ({ = ({ onCredentialsChange }) => { } catch (ex) { console.error(ex); setLoading(false); - onCredentialsChange(null); + onCredentialsChange({}); } }; diff --git a/packages/renderer/src/components/exporters/google-sheets/SheetsDropdown.tsx b/packages/renderer/src/components/exporters/google-sheets/SheetsDropdown.tsx index ef1394d2..c51c7cb9 100644 --- a/packages/renderer/src/components/exporters/google-sheets/SheetsDropdown.tsx +++ b/packages/renderer/src/components/exporters/google-sheets/SheetsDropdown.tsx @@ -3,12 +3,14 @@ import { Form } from 'react-bootstrap'; import { Typeahead } from 'react-bootstrap-typeahead'; import { useUserSpreadsheets } from './hooks'; import { type Credentials } from '/@/types'; +import { type Option } from 'react-bootstrap-typeahead/types/types'; interface SheetsDropdownProps { credentials: Credentials; value: string; onChange: (value: string) => void; } + const SheetsDropdown: React.FC = ({ credentials, value, @@ -26,10 +28,11 @@ const SheetsDropdown: React.FC = ({ }, [existedSpreadsheet, value]); const onSelectionChange = useCallback( - (selections) => { - if (selections[0]?.customOption) onChange(selections[0]?.name); - else if (selections.length) onChange(selections[0]?.id); - else onChange(null); + (selections: Option[]) => { + const selectedOption = selections[0] as { id: string; name: string; customOption?: boolean }; + if (selectedOption?.customOption) onChange(selectedOption.name); + else if (selections.length) onChange(selectedOption.id); + else onChange(''); }, [onChange], ); @@ -51,4 +54,4 @@ const SheetsDropdown: React.FC = ({ ); }; -export default SheetsDropdown; +export default SheetsDropdown; \ No newline at end of file diff --git a/packages/renderer/src/components/topBar/ReportProblemModal.tsx b/packages/renderer/src/components/topBar/ReportProblemModal.tsx index 55e47fad..b59aed29 100644 --- a/packages/renderer/src/components/topBar/ReportProblemModal.tsx +++ b/packages/renderer/src/components/topBar/ReportProblemModal.tsx @@ -23,6 +23,7 @@ interface ReportProblemModalProps { } interface ValidationError { + [key: string]: string | undefined; title?: string; email?: string; } @@ -56,7 +57,7 @@ function ReportProblemModal({ show, onClose }: ReportProblemModalProps) { const setField = (field: string, value: string) => { setForm((prevForm) => ({ ...prevForm, [field]: value })); - if (errors[field]) setErrors({ ...errors, [field]: null }); + if (errors[field]) setErrors({ ...errors, [field]: undefined }); }; const validateForm = (validateEmail = true) => { @@ -73,7 +74,7 @@ function ReportProblemModal({ show, onClose }: ReportProblemModalProps) { return newErrors; }; - const openGithub = (e) => { + const openGithub = (e: React.MouseEvent) => { e.preventDefault(); const formErrors = validateForm(false); @@ -114,19 +115,19 @@ ${details}` const sysInfo = ` ## System Info - - Source Version: \`${appInfoStore.appInfo.sourceCommitShort || 'unknown'}\` + - Source Version: \`${appInfoStore.appInfo?.sourceCommitShort ?? 'unknown'}\` - OS: \`${os.platform()}${os.arch()}\` - OS Version: \`${os.release()}\` `; return `${ - `${appInfoStore.appInfo.repository}/issues/new?` + + `${appInfoStore.appInfo?.repository}/issues/new?` + `title=${encodeURIComponent(title)}` + '&body=' }${encodeURIComponent(formattedDetails + formattedLog + sysInfo)}`; }; - const sendReport = async (e) => { + const sendReport = async (e: React.MouseEvent) => { e.preventDefault(); const formErrors = validateForm(true); @@ -233,7 +234,6 @@ ${details}` /> setShow(true)} text="דיווח על בעיה" /> openExternal(appInfoStore.appInfo?.discordChanel)} + onClick={() => openExternal(appInfoStore.appInfo?.discordChanel ?? '')} text="ערוץ הדיסקורד שלנו" /> openExternal(appInfoStore.appInfo?.repository)} + onClick={() => openExternal(appInfoStore.appInfo?.repository ?? '')} text="לפתוח ב-Github" /> @@ -51,4 +51,4 @@ function TopBar() { ); } -export default TopBar; +export default TopBar; \ No newline at end of file diff --git a/packages/renderer/src/react-bootstrap-table2-editor.d.ts b/packages/renderer/src/react-bootstrap-table2-editor.d.ts new file mode 100644 index 00000000..a0d4d2c7 --- /dev/null +++ b/packages/renderer/src/react-bootstrap-table2-editor.d.ts @@ -0,0 +1 @@ +declare module 'react-bootstrap-table2-editor'; \ No newline at end of file diff --git a/packages/renderer/src/reportWebVitals.ts b/packages/renderer/src/reportWebVitals.ts index 7fc2a19b..f8eec312 100644 --- a/packages/renderer/src/reportWebVitals.ts +++ b/packages/renderer/src/reportWebVitals.ts @@ -1,13 +1,13 @@ -import { type ReportHandler } from 'web-vitals'; +import { type MetricType } from 'web-vitals'; -const reportWebVitals = (onPerfEntry?: ReportHandler) => { - if (onPerfEntry && onPerfEntry instanceof Function) { - import('web-vitals').then(({ getCLS, getFID, getFCP, getLCP, getTTFB }) => { - getCLS(onPerfEntry); - getFID(onPerfEntry); - getFCP(onPerfEntry); - getLCP(onPerfEntry); - getTTFB(onPerfEntry); +const reportWebVitals = (onPerfEntry?: (metric: MetricType) => void) => { + if (onPerfEntry) { + import('web-vitals').then(({ onCLS, onINP, onFCP, onLCP, onTTFB }) => { + onCLS(onPerfEntry); + onINP(onPerfEntry); + onFCP(onPerfEntry); + onLCP(onPerfEntry); + onTTFB(onPerfEntry); }); } }; diff --git a/packages/renderer/src/store/AppInfoStore.tsx b/packages/renderer/src/store/AppInfoStore.tsx index f86d97ea..cec88cd8 100644 --- a/packages/renderer/src/store/AppInfoStore.tsx +++ b/packages/renderer/src/store/AppInfoStore.tsx @@ -4,7 +4,7 @@ import { createContext, useContext, useEffect } from 'react'; import { type AppInfo } from '../types'; class AppInfoStore { - appInfo: AppInfo; + appInfo: AppInfo | null = null; constructor() { makeAutoObservable(this); diff --git a/packages/renderer/src/store/ConfigStore.tsx b/packages/renderer/src/store/ConfigStore.tsx index 572cbd04..9995ffbf 100644 --- a/packages/renderer/src/store/ConfigStore.tsx +++ b/packages/renderer/src/store/ConfigStore.tsx @@ -15,7 +15,7 @@ import { type Importer, type Log, type OutputVendorName, - type DownalodChromeEvent, + type DownloadChromeEvent, } from '../types'; interface AccountScrapingData { @@ -70,7 +70,7 @@ const saveConfigIntoFile = (config?: Config) => { }; export class ConfigStore { - config: Config; + config: Config = {} as Config; chromeDownloadPercent = 0; @@ -172,7 +172,7 @@ export class ConfigStore { ) { if (eventName === 'DOWNLOAD_CHROME') { this.updateChromeDownloadPercent( - (budgetTrackingEvent as DownalodChromeEvent)?.percent, + (budgetTrackingEvent as DownloadChromeEvent)?.percent, ); } if (budgetTrackingEvent) { @@ -229,6 +229,8 @@ export class ConfigStore { } async updateExporter(updatedExporterConfig: Exporter) { + // eslint-disable-next-line @typescript-eslint/ban-ts-comment + // @ts-expect-error this.config.outputVendors[ updatedExporterConfig.companyId as OutputVendorName ] = createOutputVendorConfigFromExporter(updatedExporterConfig); diff --git a/packages/renderer/src/types.tsx b/packages/renderer/src/types.tsx index a1406117..a7f6022b 100644 --- a/packages/renderer/src/types.tsx +++ b/packages/renderer/src/types.tsx @@ -149,7 +149,7 @@ export class BudgetTrackingEvent { } } -export class DownalodChromeEvent extends BudgetTrackingEvent { +export class DownloadChromeEvent extends BudgetTrackingEvent { percent: number; constructor(percent: number) { diff --git a/yarn.lock b/yarn.lock index 4826cb11..811b8fb3 100644 --- a/yarn.lock +++ b/yarn.lock @@ -1636,6 +1636,13 @@ resolved "https://registry.yarnpkg.com/@types/range-parser/-/range-parser-1.2.7.tgz#50ae4353eaaddc04044279812f52c8c65857dbcb" integrity sha512-hKormJbkJqzQGhziax5PItDUTMAM9uE2XXQmM37dyd4hVM+5aVl7oVxMVUiVQn2oCQFN/LKCZdvSM0pFRqbSmQ== +"@types/react-bootstrap-table-next@^4.0.26": + version "4.0.26" + resolved "https://registry.yarnpkg.com/@types/react-bootstrap-table-next/-/react-bootstrap-table-next-4.0.26.tgz#06d0a290f05ae3952b6afa08d5e15d305aae8443" + integrity sha512-k9QlhxVthvEyOD6YSozJoEQVZyDEQbITfvxXEub00yw17iOAWE2g7RvnXGkXgsDshVb+vj+Z4nb0yz/FL7xsag== + dependencies: + "@types/react" "*" + "@types/react-dom@^18.3.0": version "18.3.0" resolved "https://registry.yarnpkg.com/@types/react-dom/-/react-dom-18.3.0.tgz#0cbc818755d87066ab6ca74fbedb2547d74a82b0" @@ -6921,10 +6928,10 @@ warning@^4.0.0, warning@^4.0.1, warning@^4.0.2, warning@^4.0.3: dependencies: loose-envify "^1.0.0" -web-vitals@^4.2.0: - version "4.2.0" - resolved "https://registry.yarnpkg.com/web-vitals/-/web-vitals-4.2.0.tgz#008949ab79717a68ccaaa3c4371cbc7bbbd78a92" - integrity sha512-ohj72kbtVWCpKYMxcbJ+xaOBV3En76hW47j52dG+tEGG36LZQgfFw5yHl9xyjmosy3XUMn8d/GBUAy4YPM839w== +web-vitals@^4.2.3: + version "4.2.3" + resolved "https://registry.yarnpkg.com/web-vitals/-/web-vitals-4.2.3.tgz#270c4baecfbc6ec6fc15da1989e465e5f9b94fb7" + integrity sha512-/CFAm1mNxSmOj6i0Co+iGFJ58OS4NRGVP+AWS/l509uIK5a1bSoIVaHz/ZumpHTfHSZBpgrJ+wjfpAOrTHok5Q== webidl-conversions@^3.0.0: version "3.0.1" From a7d7f1abf86af27514db85468ecb3e5c08cf8969 Mon Sep 17 00:00:00 2001 From: "shai.ungar" Date: Thu, 26 Sep 2024 12:01:14 +0300 Subject: [PATCH 11/16] lint --- .eslintrc.cjs | 2 +- packages/renderer/src/components/Body.tsx | 4 ++-- packages/renderer/src/components/accounts/Importers.tsx | 2 +- 3 files changed, 4 insertions(+), 4 deletions(-) diff --git a/.eslintrc.cjs b/.eslintrc.cjs index 9e8a4ca5..afff23f8 100644 --- a/.eslintrc.cjs +++ b/.eslintrc.cjs @@ -16,7 +16,7 @@ module.exports = { parserOptions: { ecmaVersion: 12, sourceType: 'module', - project: './tsconfig.json', + project: './tsconfig.test.json', }, plugins: ['@typescript-eslint'], ignorePatterns: ['node_modules/**', '**/dist/**'], diff --git a/packages/renderer/src/components/Body.tsx b/packages/renderer/src/components/Body.tsx index e316d29e..3b6a70e7 100644 --- a/packages/renderer/src/components/Body.tsx +++ b/packages/renderer/src/components/Body.tsx @@ -7,10 +7,10 @@ import { useConfigStore } from '../store/ConfigStore'; import { ModalStatus, OutputVendorName, - YnabConfig, + type YnabConfig, type Account, type Exporter, - type Importer, GoogleSheetsConfig, + type Importer, type GoogleSheetsConfig, } from '../types'; import styles from './Body.module.css'; import CheckForUpdates from './CheckForUpdates'; diff --git a/packages/renderer/src/components/accounts/Importers.tsx b/packages/renderer/src/components/accounts/Importers.tsx index f938f76e..a448122b 100644 --- a/packages/renderer/src/components/accounts/Importers.tsx +++ b/packages/renderer/src/components/accounts/Importers.tsx @@ -4,7 +4,7 @@ import resultsIcon from '../../assets/results.svg'; import { AccountStatus, ModalStatus, - OutputVendorName, + type OutputVendorName, AccountType as TypeOfAccount, type Account as AccountType, } from '../../types'; From 36c69f27d8969de0c2a08f5a3cbda64a56c25d80 Mon Sep 17 00:00:00 2001 From: "shai.ungar" Date: Thu, 26 Sep 2024 12:04:35 +0300 Subject: [PATCH 12/16] format --- packages/renderer/src/components/Body.tsx | 13 +++-- .../src/components/GeneralSettings.tsx | 2 +- .../src/components/accounts/EditImporter.tsx | 50 +++++++++++-------- .../src/components/exporters/EditExporter.tsx | 21 ++++++-- .../components/exporters/EditFileExporter.tsx | 8 ++- .../components/exporters/EditYnabExporter.tsx | 11 ++-- .../google-sheets/EditSheetsExporter.tsx | 7 +-- .../google-sheets/SheetsDropdown.tsx | 8 ++- .../components/topBar/ReportProblemModal.tsx | 2 +- .../renderer/src/components/topBar/TopBar.tsx | 10 ++-- .../src/react-bootstrap-table2-editor.d.ts | 2 +- 11 files changed, 82 insertions(+), 52 deletions(-) diff --git a/packages/renderer/src/components/Body.tsx b/packages/renderer/src/components/Body.tsx index 3b6a70e7..629457e9 100644 --- a/packages/renderer/src/components/Body.tsx +++ b/packages/renderer/src/components/Body.tsx @@ -10,7 +10,8 @@ import { type YnabConfig, type Account, type Exporter, - type Importer, type GoogleSheetsConfig, + type Importer, + type GoogleSheetsConfig, } from '../types'; import styles from './Body.module.css'; import CheckForUpdates from './CheckForUpdates'; @@ -83,9 +84,7 @@ const Body = () => { )} {configStore.config?.outputVendors && ( - + { {modalStatus === ModalStatus.EXPORTER_SETTINGS && currentAccount && ( Promise} + handleSave={ + updateExporter as ( + exporter: Exporter | YnabConfig | GoogleSheetsConfig, + ) => Promise + } exporter={currentAccount as Exporter} /> )} diff --git a/packages/renderer/src/components/GeneralSettings.tsx b/packages/renderer/src/components/GeneralSettings.tsx index 6a5bf899..52646b72 100644 --- a/packages/renderer/src/components/GeneralSettings.tsx +++ b/packages/renderer/src/components/GeneralSettings.tsx @@ -74,4 +74,4 @@ function GeneralSettings() { ); } -export default observer(GeneralSettings); \ No newline at end of file +export default observer(GeneralSettings); diff --git a/packages/renderer/src/components/accounts/EditImporter.tsx b/packages/renderer/src/components/accounts/EditImporter.tsx index 2b26c0c8..418643de 100644 --- a/packages/renderer/src/components/accounts/EditImporter.tsx +++ b/packages/renderer/src/components/accounts/EditImporter.tsx @@ -32,7 +32,10 @@ export default function EditImporter({ }); }; - const checkFieldValidity = (loginFieldName: keyof typeof LOGIN_FIELD_MIN_LENGTH, value: string): boolean => { + const checkFieldValidity = ( + loginFieldName: keyof typeof LOGIN_FIELD_MIN_LENGTH, + value: string, + ): boolean => { return value.length >= LOGIN_FIELD_MIN_LENGTH[loginFieldName]; }; @@ -44,7 +47,10 @@ export default function EditImporter({ ); }; - const onLoginFieldChanged = (loginFieldName: string, loginFieldValue: string) => { + const onLoginFieldChanged = ( + loginFieldName: string, + loginFieldValue: string, + ) => { setLoginFields((prevLoginFields) => { const nextLoginFields = { ...prevLoginFields, @@ -76,25 +82,27 @@ export default function EditImporter({ {IMPORTERS_LOGIN_FIELDS[ importer.companyId as keyof typeof IMPORTERS_LOGIN_FIELDS - ].map( - (loginField: string, index: number) => ( - - - onLoginFieldChanged(loginField, event.target.value) - } - autoFocus={index === 0} - /> - - ), - )} + ].map((loginField: string, index: number) => ( + + + onLoginFieldChanged(loginField, event.target.value) + } + autoFocus={index === 0} + /> + + ))} Promise; + handleSave: ( + exporterConfig: Exporter | YnabConfig | GoogleSheetsConfig, + ) => Promise; exporter: Exporter; } @@ -23,11 +30,17 @@ export default function EditExporter({ ); exporterTypeToEditComponent.set( OutputVendorName.YNAB, - , + , ); exporterTypeToEditComponent.set( OutputVendorName.GOOGLE_SHEETS, - , + , ); return <>{exporterTypeToEditComponent.get(exporter.companyId)}; } diff --git a/packages/renderer/src/components/exporters/EditFileExporter.tsx b/packages/renderer/src/components/exporters/EditFileExporter.tsx index a194944e..7087a94d 100644 --- a/packages/renderer/src/components/exporters/EditFileExporter.tsx +++ b/packages/renderer/src/components/exporters/EditFileExporter.tsx @@ -63,7 +63,13 @@ const EditFileExporter = ({ handleSave, exporter }: EditFileExporterProps) => { לאיזה קובץ לכתוב את הטרנזאקציות? diff --git a/packages/renderer/src/components/exporters/EditYnabExporter.tsx b/packages/renderer/src/components/exporters/EditYnabExporter.tsx index 6dd27470..4e81e103 100644 --- a/packages/renderer/src/components/exporters/EditYnabExporter.tsx +++ b/packages/renderer/src/components/exporters/EditYnabExporter.tsx @@ -65,7 +65,9 @@ const EditYnabExporter = ({ const handleOptionChangeEvent = ( propertyName: keyof YnabConfig['options'], - event: React.ChangeEvent, + event: React.ChangeEvent< + HTMLInputElement | HTMLSelectElement | HTMLTextAreaElement + >, ) => { updateOptionsState({ [propertyName]: event.target.value }); }; @@ -81,12 +83,7 @@ const EditYnabExporter = ({ return (
- + diff --git a/packages/renderer/src/components/exporters/google-sheets/EditSheetsExporter.tsx b/packages/renderer/src/components/exporters/google-sheets/EditSheetsExporter.tsx index dc8647ae..2a9767bc 100644 --- a/packages/renderer/src/components/exporters/google-sheets/EditSheetsExporter.tsx +++ b/packages/renderer/src/components/exporters/google-sheets/EditSheetsExporter.tsx @@ -75,12 +75,7 @@ const EditSheetsExporter: React.FC = ({ return (
- + = ({ const onSelectionChange = useCallback( (selections: Option[]) => { - const selectedOption = selections[0] as { id: string; name: string; customOption?: boolean }; + const selectedOption = selections[0] as { + id: string; + name: string; + customOption?: boolean; + }; if (selectedOption?.customOption) onChange(selectedOption.name); else if (selections.length) onChange(selectedOption.id); else onChange(''); @@ -54,4 +58,4 @@ const SheetsDropdown: React.FC = ({ ); }; -export default SheetsDropdown; \ No newline at end of file +export default SheetsDropdown; diff --git a/packages/renderer/src/components/topBar/ReportProblemModal.tsx b/packages/renderer/src/components/topBar/ReportProblemModal.tsx index b59aed29..a0949e9e 100644 --- a/packages/renderer/src/components/topBar/ReportProblemModal.tsx +++ b/packages/renderer/src/components/topBar/ReportProblemModal.tsx @@ -285,4 +285,4 @@ ${details}` ); } -export default ReportProblemModal; \ No newline at end of file +export default ReportProblemModal; diff --git a/packages/renderer/src/components/topBar/TopBar.tsx b/packages/renderer/src/components/topBar/TopBar.tsx index 7db2f3dd..46943b80 100644 --- a/packages/renderer/src/components/topBar/TopBar.tsx +++ b/packages/renderer/src/components/topBar/TopBar.tsx @@ -36,11 +36,15 @@ function TopBar() { setShow(true)} text="דיווח על בעיה" /> openExternal(appInfoStore.appInfo?.discordChanel ?? '')} + onClick={() => + openExternal(appInfoStore.appInfo?.discordChanel ?? '') + } text="ערוץ הדיסקורד שלנו" /> openExternal(appInfoStore.appInfo?.repository ?? '')} + onClick={() => + openExternal(appInfoStore.appInfo?.repository ?? '') + } text="לפתוח ב-Github" /> @@ -51,4 +55,4 @@ function TopBar() { ); } -export default TopBar; \ No newline at end of file +export default TopBar; diff --git a/packages/renderer/src/react-bootstrap-table2-editor.d.ts b/packages/renderer/src/react-bootstrap-table2-editor.d.ts index a0d4d2c7..1eaa5f34 100644 --- a/packages/renderer/src/react-bootstrap-table2-editor.d.ts +++ b/packages/renderer/src/react-bootstrap-table2-editor.d.ts @@ -1 +1 @@ -declare module 'react-bootstrap-table2-editor'; \ No newline at end of file +declare module 'react-bootstrap-table2-editor'; From 5294c7d017236209b5cf2cb0cb003a391b39a26e Mon Sep 17 00:00:00 2001 From: Baruch Odem Date: Wed, 9 Oct 2024 20:59:48 +0300 Subject: [PATCH 13/16] write a message --- packages/renderer/src/store/ConfigStore.tsx | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/packages/renderer/src/store/ConfigStore.tsx b/packages/renderer/src/store/ConfigStore.tsx index 9995ffbf..810f101b 100644 --- a/packages/renderer/src/store/ConfigStore.tsx +++ b/packages/renderer/src/store/ConfigStore.tsx @@ -229,8 +229,7 @@ export class ConfigStore { } async updateExporter(updatedExporterConfig: Exporter) { - // eslint-disable-next-line @typescript-eslint/ban-ts-comment - // @ts-expect-error + // @ts-expect-error the types are not complete here this.config.outputVendors[ updatedExporterConfig.companyId as OutputVendorName ] = createOutputVendorConfigFromExporter(updatedExporterConfig); From 4638dda247afb8635cd51e342e2014d7223c0244 Mon Sep 17 00:00:00 2001 From: Baruch Odem Date: Wed, 9 Oct 2024 21:15:02 +0300 Subject: [PATCH 14/16] Refactor exporter update function in Body component --- packages/renderer/src/components/Body.tsx | 14 ++++++-------- .../renderer/src/components/GeneralSettings.tsx | 2 +- .../src/components/exporters/EditExporter.tsx | 2 +- packages/renderer/src/components/topBar/TopBar.tsx | 6 ++++-- packages/renderer/src/store/Store.test.tsx | 8 ++++---- 5 files changed, 16 insertions(+), 16 deletions(-) diff --git a/packages/renderer/src/components/Body.tsx b/packages/renderer/src/components/Body.tsx index 629457e9..27ff617e 100644 --- a/packages/renderer/src/components/Body.tsx +++ b/packages/renderer/src/components/Body.tsx @@ -22,7 +22,7 @@ import AccountsContainer from './accounts/AccountsContainer'; import CreateImporter from './accounts/CreateImporter'; import EditImporter from './accounts/EditImporter'; import Importers from './accounts/Importers'; -import EditExporter from './exporters/EditExporter'; +import EditExporter, { type EditExporterProps } from './exporters/EditExporter'; import Exporters from './exporters/Exporters'; const Body = () => { @@ -58,8 +58,10 @@ const Body = () => { closeModal(); }; - const updateExporter = async (exporter: Exporter) => { - await configStore.updateExporter(exporter); + const updateExporter: EditExporterProps['handleSave'] = async ( + exporter: Exporter | YnabConfig | GoogleSheetsConfig, + ) => { + await configStore.updateExporter(exporter as Exporter); closeModal(); }; @@ -118,11 +120,7 @@ const Body = () => { {modalStatus === ModalStatus.EXPORTER_SETTINGS && currentAccount && ( Promise - } + handleSave={updateExporter} exporter={currentAccount as Exporter} /> )} diff --git a/packages/renderer/src/components/GeneralSettings.tsx b/packages/renderer/src/components/GeneralSettings.tsx index 52646b72..1b77db03 100644 --- a/packages/renderer/src/components/GeneralSettings.tsx +++ b/packages/renderer/src/components/GeneralSettings.tsx @@ -60,7 +60,7 @@ function GeneralSettings() { /> - כמה זמן לחכות לשליפה? (millisecond) + כמה זמן לחכות לשליפה? (milliseconds) Promise; diff --git a/packages/renderer/src/components/topBar/TopBar.tsx b/packages/renderer/src/components/topBar/TopBar.tsx index 46943b80..4fd00d7c 100644 --- a/packages/renderer/src/components/topBar/TopBar.tsx +++ b/packages/renderer/src/components/topBar/TopBar.tsx @@ -37,13 +37,15 @@ function TopBar() { setShow(true)} text="דיווח על בעיה" /> - openExternal(appInfoStore.appInfo?.discordChanel ?? '') + appInfoStore.appInfo?.discordChanel && + openExternal(appInfoStore.appInfo?.discordChanel) } text="ערוץ הדיסקורד שלנו" /> - openExternal(appInfoStore.appInfo?.repository ?? '') + appInfoStore.appInfo?.repository && + openExternal(appInfoStore.appInfo?.repository) } text="לפתוח ב-Github" /> diff --git a/packages/renderer/src/store/Store.test.tsx b/packages/renderer/src/store/Store.test.tsx index 448ab4b4..634d31cf 100644 --- a/packages/renderer/src/store/Store.test.tsx +++ b/packages/renderer/src/store/Store.test.tsx @@ -30,13 +30,13 @@ describe('Store', () => { expect(store.importers).toHaveLength(3); const discountImporter = store.importers.find( - (i: Importer) => i.companyId === 'discount', + (importer) => importer.companyId === 'discount', ); const visaCalImporter = store.importers.find( - (i: Importer) => i.companyId === 'visaCal', + (importer) => importer.companyId === 'visaCal', ); const maxImporter = store.importers.find( - (i: Importer) => i.companyId === 'max', + (importer) => importer.companyId === 'max', ); expect(discountImporter).toMatchSnapshot(); @@ -86,7 +86,7 @@ describe('Store', () => { }; store.updateImporter(importer.id, updatedImporter); expect( - store.importers.find((i: Importer) => i.id === importer.id), + store.importers.find((importer) => importer.id === importer.id), ).toHaveProperty('active', updatedImporter.active); }); From 10d69536b29b0287963aaa9942ceb8a334789c0c Mon Sep 17 00:00:00 2001 From: Shai Ungar Date: Wed, 9 Oct 2024 21:36:20 +0300 Subject: [PATCH 15/16] Update package.json Co-authored-by: Baruch Odem (Rothkoff) --- package.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/package.json b/package.json index 52294bd6..83a05c53 100644 --- a/package.json +++ b/package.json @@ -22,7 +22,7 @@ "test:renderer": "vitest run -r packages/renderer --passWithNoTests", "watch": "node scripts/watch.js", "lint": "eslint . --ext js,mjs,cjs,ts,mts,cts,tsx", - "lint:fix": "eslint . --fix --ext js,mjs,cjs,ts,mts,cts,tsx", + "lint:fix": "yarn lint --fix", "typecheck:main": "tsc --noEmit -p packages/main/tsconfig.json", "typecheck:preload": "tsc --noEmit -p packages/preload/tsconfig.json", "typecheck:renderer": "tsc --noEmit -p packages/renderer/tsconfig.json", From f0adbca446519b58c221f0e0c232cb9f815a1e97 Mon Sep 17 00:00:00 2001 From: "shai.ungar" Date: Wed, 9 Oct 2024 21:45:01 +0300 Subject: [PATCH 16/16] remove vite-plugin-node-polyfills --- package.json | 1 - 1 file changed, 1 deletion(-) diff --git a/package.json b/package.json index 83a05c53..1cb68313 100644 --- a/package.json +++ b/package.json @@ -96,7 +96,6 @@ "react-bootstrap-typeahead": "^6.3.2", "react-dom": "^18.3.1", "svelte": "^4.2.19", - "vite-plugin-node-polyfills": "^0.22.0", "web-vitals": "^4.2.3", "ynab": "^1.19.0" }