From 4a0a5b70177310fd95a04ad5fc0aeba690147c17 Mon Sep 17 00:00:00 2001 From: DominicGBauer Date: Wed, 29 Nov 2023 17:56:23 +0200 Subject: [PATCH] chore: try docusaurus --- .github/workflows/deploy-docs.yaml | 6 +- .gitignore | 1 - README.md | 26 +- docs/.gitignore | 20 + docs/README.md | 41 + docs/babel.config.js | 3 + docs/docs/attachments-sdk/_category_.yml | 1 + .../classes/AbstractAttachmentQueue.md | 514 + .../classes/AttachmentTable.md | 251 + .../attachments-sdk/classes/_category_.yml | 2 + .../attachments-sdk/enums/AttachmentState.md | 57 + .../attachments-sdk/enums/EncodingType.md | 27 + .../docs/attachments-sdk/enums/_category_.yml | 2 + docs/docs/attachments-sdk/index.md | 236 + .../interfaces/AttachmentQueueOptions.md | 75 + .../interfaces/AttachmentRecord.md | 77 + .../interfaces/AttachmentTableOptions.md | 75 + .../interfaces/StorageAdapter.md | 196 + .../attachments-sdk/interfaces/_category_.yml | 2 + docs/docs/attachments-sdk/modules.md | 44 + docs/docs/common-sdk/_category_.yml | 1 + .../classes/AbstractPowerSyncDatabase.md | 819 ++ .../AbstractPowerSyncDatabaseOpenFactory.md | 113 + .../docs/common-sdk/classes/AbstractRemote.md | 180 + .../AbstractStreamingSyncImplementation.md | 384 + docs/docs/common-sdk/classes/BaseObserver.md | 109 + docs/docs/common-sdk/classes/Column.md | 84 + docs/docs/common-sdk/classes/CrudBatch.md | 79 + docs/docs/common-sdk/classes/CrudEntry.md | 140 + .../common-sdk/classes/CrudTransaction.md | 105 + docs/docs/common-sdk/classes/Index.md | 111 + docs/docs/common-sdk/classes/IndexedColumn.md | 111 + docs/docs/common-sdk/classes/OpType.md | 71 + docs/docs/common-sdk/classes/Schema.md | 55 + .../common-sdk/classes/SqliteBucketStorage.md | 536 + docs/docs/common-sdk/classes/SyncDataBatch.md | 57 + .../docs/common-sdk/classes/SyncDataBucket.md | 121 + docs/docs/common-sdk/classes/SyncStatus.md | 62 + docs/docs/common-sdk/classes/Table.md | 197 + .../common-sdk/classes/UploadQueueStats.md | 62 + docs/docs/common-sdk/classes/_category_.yml | 2 + docs/docs/common-sdk/enums/ColumnType.md | 37 + docs/docs/common-sdk/enums/LockType.md | 27 + docs/docs/common-sdk/enums/OpTypeEnum.md | 47 + docs/docs/common-sdk/enums/RowUpdateType.md | 39 + docs/docs/common-sdk/enums/UpdateType.md | 37 + docs/docs/common-sdk/enums/_category_.yml | 2 + docs/docs/common-sdk/index.md | 14 + ...tractStreamingSyncImplementationOptions.md | 65 + .../interfaces/BaseObserverInterface.md | 49 + .../common-sdk/interfaces/BucketChecksum.md | 41 + .../common-sdk/interfaces/BucketRequest.md | 29 + .../docs/common-sdk/interfaces/BucketState.md | 27 + .../interfaces/BucketStorageAdapter.md | 247 + docs/docs/common-sdk/interfaces/Checkpoint.md | 37 + .../common-sdk/interfaces/ChecksumCache.md | 27 + .../common-sdk/interfaces/ColumnOptions.md | 27 + .../interfaces/ContinueCheckpointRequest.md | 41 + .../docs/common-sdk/interfaces/CrudRequest.md | 19 + .../common-sdk/interfaces/CrudResponse.md | 23 + docs/docs/common-sdk/interfaces/DBAdapter.md | 305 + .../interfaces/DBAdapterListener.md | 37 + docs/docs/common-sdk/interfaces/DBGetUtils.md | 96 + .../common-sdk/interfaces/DBLockOptions.md | 17 + .../interfaces/IndexColumnOptions.md | 27 + .../common-sdk/interfaces/IndexOptions.md | 27 + .../docs/common-sdk/interfaces/LockContext.md | 133 + .../docs/common-sdk/interfaces/LockOptions.md | 53 + .../interfaces/PowerSyncBackendConnector.md | 65 + .../interfaces/PowerSyncCredentials.md | 37 + .../interfaces/PowerSyncDBListener.md | 59 + .../interfaces/PowerSyncDatabaseOptions.md | 47 + .../interfaces/PowerSyncOpenFactoryOptions.md | 41 + .../docs/common-sdk/interfaces/QueryResult.md | 54 + .../common-sdk/interfaces/SQLWatchOptions.md | 37 + .../interfaces/StreamingSyncCheckpoint.md | 17 + .../StreamingSyncCheckpointComplete.md | 23 + .../interfaces/StreamingSyncCheckpointDiff.md | 26 + .../interfaces/StreamingSyncDataJSON.md | 17 + .../StreamingSyncImplementationListener.md | 39 + .../interfaces/StreamingSyncKeepalive.md | 19 + .../interfaces/StreamingSyncRequest.md | 55 + .../interfaces/SyncLocalDatabaseResult.md | 37 + .../interfaces/SyncNewCheckpointRequest.md | 46 + .../common-sdk/interfaces/SyncResponse.md | 51 + .../common-sdk/interfaces/TableOptions.md | 57 + .../docs/common-sdk/interfaces/Transaction.md | 171 + .../interfaces/UpdateNotification.md | 37 + .../interfaces/WatchOnChangeEvent.md | 17 + .../docs/common-sdk/interfaces/_category_.yml | 2 + docs/docs/common-sdk/modules.md | 523 + docs/docs/index.md | 94 + docs/docs/react-native-sdk/_category_.yml | 1 + .../classes/AbstractPowerSyncDatabase.md | 802 ++ .../AbstractPowerSyncDatabaseOpenFactory.md | 119 + .../classes/AbstractRemote.md | 186 + .../AbstractStreamingSyncImplementation.md | 371 + .../react-native-sdk/classes/BaseObserver.md | 111 + docs/docs/react-native-sdk/classes/Column.md | 84 + .../react-native-sdk/classes/CrudBatch.md | 79 + .../react-native-sdk/classes/CrudEntry.md | 140 + .../classes/CrudTransaction.md | 105 + docs/docs/react-native-sdk/classes/Index.md | 111 + .../react-native-sdk/classes/IndexedColumn.md | 111 + docs/docs/react-native-sdk/classes/OpType.md | 71 + .../classes/PowerSyncDatabase.md | 910 ++ .../react-native-sdk/classes/RNQSDBAdapter.md | 455 + .../RNQSPowerSyncDatabaseOpenFactory.md | 147 + .../classes/ReactNativeRemote.md | 230 + .../ReactNativeStreamingSyncImplementation.md | 409 + docs/docs/react-native-sdk/classes/Schema.md | 55 + .../classes/SqliteBucketStorage.md | 510 + .../react-native-sdk/classes/SyncDataBatch.md | 57 + .../classes/SyncDataBucket.md | 121 + .../react-native-sdk/classes/SyncStatus.md | 62 + docs/docs/react-native-sdk/classes/Table.md | 197 + .../classes/UploadQueueStats.md | 62 + .../react-native-sdk/classes/_category_.yml | 2 + .../docs/react-native-sdk/enums/ColumnType.md | 37 + docs/docs/react-native-sdk/enums/LockType.md | 27 + .../docs/react-native-sdk/enums/OpTypeEnum.md | 47 + .../react-native-sdk/enums/RowUpdateType.md | 39 + .../docs/react-native-sdk/enums/UpdateType.md | 37 + .../react-native-sdk/enums/_category_.yml | 2 + docs/docs/react-native-sdk/index.md | 198 + ...tractStreamingSyncImplementationOptions.md | 65 + .../interfaces/BaseObserverInterface.md | 49 + .../interfaces/BucketChecksum.md | 41 + .../interfaces/BucketRequest.md | 29 + .../interfaces/BucketState.md | 27 + .../interfaces/BucketStorageAdapter.md | 247 + .../react-native-sdk/interfaces/Checkpoint.md | 37 + .../interfaces/ChecksumCache.md | 27 + .../interfaces/ColumnOptions.md | 27 + .../interfaces/ContinueCheckpointRequest.md | 41 + .../interfaces/CrudRequest.md | 19 + .../interfaces/CrudResponse.md | 23 + .../react-native-sdk/interfaces/DBAdapter.md | 309 + .../interfaces/DBAdapterListener.md | 37 + .../react-native-sdk/interfaces/DBGetUtils.md | 96 + .../interfaces/DBLockOptions.md | 17 + .../interfaces/IndexColumnOptions.md | 27 + .../interfaces/IndexOptions.md | 27 + .../interfaces/LockContext.md | 133 + .../interfaces/LockOptions.md | 53 + .../interfaces/PowerSyncBackendConnector.md | 65 + .../interfaces/PowerSyncCredentials.md | 37 + .../interfaces/PowerSyncDBListener.md | 59 + .../interfaces/PowerSyncDatabaseOptions.md | 47 + .../interfaces/PowerSyncOpenFactoryOptions.md | 41 + .../interfaces/QueryResult.md | 54 + .../interfaces/SQLWatchOptions.md | 37 + .../interfaces/StreamingSyncCheckpoint.md | 17 + .../StreamingSyncCheckpointComplete.md | 23 + .../interfaces/StreamingSyncCheckpointDiff.md | 26 + .../interfaces/StreamingSyncDataJSON.md | 17 + .../StreamingSyncImplementationListener.md | 39 + .../interfaces/StreamingSyncKeepalive.md | 19 + .../interfaces/StreamingSyncRequest.md | 55 + .../interfaces/SyncLocalDatabaseResult.md | 37 + .../interfaces/SyncNewCheckpointRequest.md | 46 + .../interfaces/SyncResponse.md | 51 + .../interfaces/TableOptions.md | 57 + .../interfaces/Transaction.md | 171 + .../interfaces/UpdateNotification.md | 37 + .../interfaces/WatchOnChangeEvent.md | 17 + .../interfaces/_category_.yml | 2 + docs/docs/react-native-sdk/modules.md | 622 ++ docs/docs/react-sdk/_category_.yml | 1 + docs/docs/react-sdk/index.md | 68 + docs/docs/react-sdk/modules.md | 91 + docs/docusaurus.config.ts | 175 + docs/package.json | 50 + docs/sidebars.ts | 63 + docs/src/css/custom.css | 30 + docs/src/pages/index.module.css | 23 + docs/src/pages/markdown-page.md | 7 + docs/static/.nojekyll | 0 docs/static/img/powersync-favicon.png | Bin 0 -> 1208 bytes docs/static/img/powersync-logo.png | Bin 0 -> 12456 bytes docs/tsconfig.json | 7 + docs/yarn.lock | 8661 +++++++++++++++++ package.json | 4 +- packages/powersync-attachments/package.json | 1 - packages/powersync-react/package.json | 1 - packages/powersync-sdk-common/package.json | 1 - .../powersync-sdk-react-native/package.json | 1 - 187 files changed, 26121 insertions(+), 21 deletions(-) create mode 100644 docs/.gitignore create mode 100644 docs/README.md create mode 100644 docs/babel.config.js create mode 100644 docs/docs/attachments-sdk/_category_.yml create mode 100644 docs/docs/attachments-sdk/classes/AbstractAttachmentQueue.md create mode 100644 docs/docs/attachments-sdk/classes/AttachmentTable.md create mode 100644 docs/docs/attachments-sdk/classes/_category_.yml create mode 100644 docs/docs/attachments-sdk/enums/AttachmentState.md create mode 100644 docs/docs/attachments-sdk/enums/EncodingType.md create mode 100644 docs/docs/attachments-sdk/enums/_category_.yml create mode 100644 docs/docs/attachments-sdk/index.md create mode 100644 docs/docs/attachments-sdk/interfaces/AttachmentQueueOptions.md create mode 100644 docs/docs/attachments-sdk/interfaces/AttachmentRecord.md create mode 100644 docs/docs/attachments-sdk/interfaces/AttachmentTableOptions.md create mode 100644 docs/docs/attachments-sdk/interfaces/StorageAdapter.md create mode 100644 docs/docs/attachments-sdk/interfaces/_category_.yml create mode 100644 docs/docs/attachments-sdk/modules.md create mode 100644 docs/docs/common-sdk/_category_.yml create mode 100644 docs/docs/common-sdk/classes/AbstractPowerSyncDatabase.md create mode 100644 docs/docs/common-sdk/classes/AbstractPowerSyncDatabaseOpenFactory.md create mode 100644 docs/docs/common-sdk/classes/AbstractRemote.md create mode 100644 docs/docs/common-sdk/classes/AbstractStreamingSyncImplementation.md create mode 100644 docs/docs/common-sdk/classes/BaseObserver.md create mode 100644 docs/docs/common-sdk/classes/Column.md create mode 100644 docs/docs/common-sdk/classes/CrudBatch.md create mode 100644 docs/docs/common-sdk/classes/CrudEntry.md create mode 100644 docs/docs/common-sdk/classes/CrudTransaction.md create mode 100644 docs/docs/common-sdk/classes/Index.md create mode 100644 docs/docs/common-sdk/classes/IndexedColumn.md create mode 100644 docs/docs/common-sdk/classes/OpType.md create mode 100644 docs/docs/common-sdk/classes/Schema.md create mode 100644 docs/docs/common-sdk/classes/SqliteBucketStorage.md create mode 100644 docs/docs/common-sdk/classes/SyncDataBatch.md create mode 100644 docs/docs/common-sdk/classes/SyncDataBucket.md create mode 100644 docs/docs/common-sdk/classes/SyncStatus.md create mode 100644 docs/docs/common-sdk/classes/Table.md create mode 100644 docs/docs/common-sdk/classes/UploadQueueStats.md create mode 100644 docs/docs/common-sdk/classes/_category_.yml create mode 100644 docs/docs/common-sdk/enums/ColumnType.md create mode 100644 docs/docs/common-sdk/enums/LockType.md create mode 100644 docs/docs/common-sdk/enums/OpTypeEnum.md create mode 100644 docs/docs/common-sdk/enums/RowUpdateType.md create mode 100644 docs/docs/common-sdk/enums/UpdateType.md create mode 100644 docs/docs/common-sdk/enums/_category_.yml create mode 100644 docs/docs/common-sdk/index.md create mode 100644 docs/docs/common-sdk/interfaces/AbstractStreamingSyncImplementationOptions.md create mode 100644 docs/docs/common-sdk/interfaces/BaseObserverInterface.md create mode 100644 docs/docs/common-sdk/interfaces/BucketChecksum.md create mode 100644 docs/docs/common-sdk/interfaces/BucketRequest.md create mode 100644 docs/docs/common-sdk/interfaces/BucketState.md create mode 100644 docs/docs/common-sdk/interfaces/BucketStorageAdapter.md create mode 100644 docs/docs/common-sdk/interfaces/Checkpoint.md create mode 100644 docs/docs/common-sdk/interfaces/ChecksumCache.md create mode 100644 docs/docs/common-sdk/interfaces/ColumnOptions.md create mode 100644 docs/docs/common-sdk/interfaces/ContinueCheckpointRequest.md create mode 100644 docs/docs/common-sdk/interfaces/CrudRequest.md create mode 100644 docs/docs/common-sdk/interfaces/CrudResponse.md create mode 100644 docs/docs/common-sdk/interfaces/DBAdapter.md create mode 100644 docs/docs/common-sdk/interfaces/DBAdapterListener.md create mode 100644 docs/docs/common-sdk/interfaces/DBGetUtils.md create mode 100644 docs/docs/common-sdk/interfaces/DBLockOptions.md create mode 100644 docs/docs/common-sdk/interfaces/IndexColumnOptions.md create mode 100644 docs/docs/common-sdk/interfaces/IndexOptions.md create mode 100644 docs/docs/common-sdk/interfaces/LockContext.md create mode 100644 docs/docs/common-sdk/interfaces/LockOptions.md create mode 100644 docs/docs/common-sdk/interfaces/PowerSyncBackendConnector.md create mode 100644 docs/docs/common-sdk/interfaces/PowerSyncCredentials.md create mode 100644 docs/docs/common-sdk/interfaces/PowerSyncDBListener.md create mode 100644 docs/docs/common-sdk/interfaces/PowerSyncDatabaseOptions.md create mode 100644 docs/docs/common-sdk/interfaces/PowerSyncOpenFactoryOptions.md create mode 100644 docs/docs/common-sdk/interfaces/QueryResult.md create mode 100644 docs/docs/common-sdk/interfaces/SQLWatchOptions.md create mode 100644 docs/docs/common-sdk/interfaces/StreamingSyncCheckpoint.md create mode 100644 docs/docs/common-sdk/interfaces/StreamingSyncCheckpointComplete.md create mode 100644 docs/docs/common-sdk/interfaces/StreamingSyncCheckpointDiff.md create mode 100644 docs/docs/common-sdk/interfaces/StreamingSyncDataJSON.md create mode 100644 docs/docs/common-sdk/interfaces/StreamingSyncImplementationListener.md create mode 100644 docs/docs/common-sdk/interfaces/StreamingSyncKeepalive.md create mode 100644 docs/docs/common-sdk/interfaces/StreamingSyncRequest.md create mode 100644 docs/docs/common-sdk/interfaces/SyncLocalDatabaseResult.md create mode 100644 docs/docs/common-sdk/interfaces/SyncNewCheckpointRequest.md create mode 100644 docs/docs/common-sdk/interfaces/SyncResponse.md create mode 100644 docs/docs/common-sdk/interfaces/TableOptions.md create mode 100644 docs/docs/common-sdk/interfaces/Transaction.md create mode 100644 docs/docs/common-sdk/interfaces/UpdateNotification.md create mode 100644 docs/docs/common-sdk/interfaces/WatchOnChangeEvent.md create mode 100644 docs/docs/common-sdk/interfaces/_category_.yml create mode 100644 docs/docs/common-sdk/modules.md create mode 100644 docs/docs/index.md create mode 100644 docs/docs/react-native-sdk/_category_.yml create mode 100644 docs/docs/react-native-sdk/classes/AbstractPowerSyncDatabase.md create mode 100644 docs/docs/react-native-sdk/classes/AbstractPowerSyncDatabaseOpenFactory.md create mode 100644 docs/docs/react-native-sdk/classes/AbstractRemote.md create mode 100644 docs/docs/react-native-sdk/classes/AbstractStreamingSyncImplementation.md create mode 100644 docs/docs/react-native-sdk/classes/BaseObserver.md create mode 100644 docs/docs/react-native-sdk/classes/Column.md create mode 100644 docs/docs/react-native-sdk/classes/CrudBatch.md create mode 100644 docs/docs/react-native-sdk/classes/CrudEntry.md create mode 100644 docs/docs/react-native-sdk/classes/CrudTransaction.md create mode 100644 docs/docs/react-native-sdk/classes/Index.md create mode 100644 docs/docs/react-native-sdk/classes/IndexedColumn.md create mode 100644 docs/docs/react-native-sdk/classes/OpType.md create mode 100644 docs/docs/react-native-sdk/classes/PowerSyncDatabase.md create mode 100644 docs/docs/react-native-sdk/classes/RNQSDBAdapter.md create mode 100644 docs/docs/react-native-sdk/classes/RNQSPowerSyncDatabaseOpenFactory.md create mode 100644 docs/docs/react-native-sdk/classes/ReactNativeRemote.md create mode 100644 docs/docs/react-native-sdk/classes/ReactNativeStreamingSyncImplementation.md create mode 100644 docs/docs/react-native-sdk/classes/Schema.md create mode 100644 docs/docs/react-native-sdk/classes/SqliteBucketStorage.md create mode 100644 docs/docs/react-native-sdk/classes/SyncDataBatch.md create mode 100644 docs/docs/react-native-sdk/classes/SyncDataBucket.md create mode 100644 docs/docs/react-native-sdk/classes/SyncStatus.md create mode 100644 docs/docs/react-native-sdk/classes/Table.md create mode 100644 docs/docs/react-native-sdk/classes/UploadQueueStats.md create mode 100644 docs/docs/react-native-sdk/classes/_category_.yml create mode 100644 docs/docs/react-native-sdk/enums/ColumnType.md create mode 100644 docs/docs/react-native-sdk/enums/LockType.md create mode 100644 docs/docs/react-native-sdk/enums/OpTypeEnum.md create mode 100644 docs/docs/react-native-sdk/enums/RowUpdateType.md create mode 100644 docs/docs/react-native-sdk/enums/UpdateType.md create mode 100644 docs/docs/react-native-sdk/enums/_category_.yml create mode 100644 docs/docs/react-native-sdk/index.md create mode 100644 docs/docs/react-native-sdk/interfaces/AbstractStreamingSyncImplementationOptions.md create mode 100644 docs/docs/react-native-sdk/interfaces/BaseObserverInterface.md create mode 100644 docs/docs/react-native-sdk/interfaces/BucketChecksum.md create mode 100644 docs/docs/react-native-sdk/interfaces/BucketRequest.md create mode 100644 docs/docs/react-native-sdk/interfaces/BucketState.md create mode 100644 docs/docs/react-native-sdk/interfaces/BucketStorageAdapter.md create mode 100644 docs/docs/react-native-sdk/interfaces/Checkpoint.md create mode 100644 docs/docs/react-native-sdk/interfaces/ChecksumCache.md create mode 100644 docs/docs/react-native-sdk/interfaces/ColumnOptions.md create mode 100644 docs/docs/react-native-sdk/interfaces/ContinueCheckpointRequest.md create mode 100644 docs/docs/react-native-sdk/interfaces/CrudRequest.md create mode 100644 docs/docs/react-native-sdk/interfaces/CrudResponse.md create mode 100644 docs/docs/react-native-sdk/interfaces/DBAdapter.md create mode 100644 docs/docs/react-native-sdk/interfaces/DBAdapterListener.md create mode 100644 docs/docs/react-native-sdk/interfaces/DBGetUtils.md create mode 100644 docs/docs/react-native-sdk/interfaces/DBLockOptions.md create mode 100644 docs/docs/react-native-sdk/interfaces/IndexColumnOptions.md create mode 100644 docs/docs/react-native-sdk/interfaces/IndexOptions.md create mode 100644 docs/docs/react-native-sdk/interfaces/LockContext.md create mode 100644 docs/docs/react-native-sdk/interfaces/LockOptions.md create mode 100644 docs/docs/react-native-sdk/interfaces/PowerSyncBackendConnector.md create mode 100644 docs/docs/react-native-sdk/interfaces/PowerSyncCredentials.md create mode 100644 docs/docs/react-native-sdk/interfaces/PowerSyncDBListener.md create mode 100644 docs/docs/react-native-sdk/interfaces/PowerSyncDatabaseOptions.md create mode 100644 docs/docs/react-native-sdk/interfaces/PowerSyncOpenFactoryOptions.md create mode 100644 docs/docs/react-native-sdk/interfaces/QueryResult.md create mode 100644 docs/docs/react-native-sdk/interfaces/SQLWatchOptions.md create mode 100644 docs/docs/react-native-sdk/interfaces/StreamingSyncCheckpoint.md create mode 100644 docs/docs/react-native-sdk/interfaces/StreamingSyncCheckpointComplete.md create mode 100644 docs/docs/react-native-sdk/interfaces/StreamingSyncCheckpointDiff.md create mode 100644 docs/docs/react-native-sdk/interfaces/StreamingSyncDataJSON.md create mode 100644 docs/docs/react-native-sdk/interfaces/StreamingSyncImplementationListener.md create mode 100644 docs/docs/react-native-sdk/interfaces/StreamingSyncKeepalive.md create mode 100644 docs/docs/react-native-sdk/interfaces/StreamingSyncRequest.md create mode 100644 docs/docs/react-native-sdk/interfaces/SyncLocalDatabaseResult.md create mode 100644 docs/docs/react-native-sdk/interfaces/SyncNewCheckpointRequest.md create mode 100644 docs/docs/react-native-sdk/interfaces/SyncResponse.md create mode 100644 docs/docs/react-native-sdk/interfaces/TableOptions.md create mode 100644 docs/docs/react-native-sdk/interfaces/Transaction.md create mode 100644 docs/docs/react-native-sdk/interfaces/UpdateNotification.md create mode 100644 docs/docs/react-native-sdk/interfaces/WatchOnChangeEvent.md create mode 100644 docs/docs/react-native-sdk/interfaces/_category_.yml create mode 100644 docs/docs/react-native-sdk/modules.md create mode 100644 docs/docs/react-sdk/_category_.yml create mode 100644 docs/docs/react-sdk/index.md create mode 100644 docs/docs/react-sdk/modules.md create mode 100644 docs/docusaurus.config.ts create mode 100644 docs/package.json create mode 100644 docs/sidebars.ts create mode 100644 docs/src/css/custom.css create mode 100644 docs/src/pages/index.module.css create mode 100644 docs/src/pages/markdown-page.md create mode 100644 docs/static/.nojekyll create mode 100644 docs/static/img/powersync-favicon.png create mode 100644 docs/static/img/powersync-logo.png create mode 100644 docs/tsconfig.json create mode 100644 docs/yarn.lock diff --git a/.github/workflows/deploy-docs.yaml b/.github/workflows/deploy-docs.yaml index 08f15e25..c051a683 100644 --- a/.github/workflows/deploy-docs.yaml +++ b/.github/workflows/deploy-docs.yaml @@ -32,11 +32,11 @@ jobs: run: yarn install --frozen-lockfile - name: Build Packages run: yarn build:packages - - name: Combine Docs - run: yarn docs + - name: Create Docs + run: cd docs && yarn build - uses: actions/upload-pages-artifact@v2 with: - path: ./docs + path: ./docs/build deploy: runs-on: ubuntu-latest environment: diff --git a/.gitignore b/.gitignore index bbf5f98d..91a3b1f3 100644 --- a/.gitignore +++ b/.gitignore @@ -6,4 +6,3 @@ yarn-error.log .vscode .DS_STORE .idea -/docs diff --git a/README.md b/README.md index 845e92e3..a2c4fba3 100644 --- a/README.md +++ b/README.md @@ -4,18 +4,19 @@ Monorepo for all things React Native and PowerSync. ## Monorepo Structure -- [apps/supabase-todolist](./apps/supabase-todolist/README.md) - * An Expo React native app using Supabase. +- [apps/supabase-todolist](https://github.com/powersync-ja/powersync-supabase-react-native-todolist-demo/tree/e6a1d045ab8244041651757402adc562a6699a4f) + - An Expo React native app using Supabase. - [packages/powersync-sdk-common](./packages/powersync-sdk-common/README.md) - * A Typescript implementation of a PowerSync database connector and streaming sync bucket implementation. + - A Typescript implementation of a PowerSync database connector and streaming sync bucket implementation. - [packages/powersync-sdk-react-native](./packages/powersync-sdk-react-native/README.md) - * An extension of `packages/powersync-sdk-common` which provides React Native specific implementations of abstracted features. + - An extension of `packages/powersync-sdk-common` which provides React Native specific implementations of abstracted features. # Development ## Git Submodules + After cloning this repo be sure to init the Git submodules ```bash @@ -25,41 +26,45 @@ git submodule init && git submodule update This monorepo uses Yarn as it works well with React native. Install workspace dependencies + ```bash yarn install ``` Build packages + ```bash yarn build:packages ``` - ## Versioning - ### Development Packages -Development packages can be published by manually triggering the `dev-packages` workflow. Development packages are versioned as `0.0.0-{tag}-DATETIMESTAMP`. + +Development packages can be published by manually triggering the `dev-packages` workflow. Development packages are versioned as `0.0.0-{tag}-DATETIMESTAMP`. ### Production Packages + Pull requests should contain Changesets for changed packages. Add changesets with + ```Bash yarn changeset add ``` -Merging a PR with Changesets will automatically create a PR with version bumps. That PR will be merged when releasing. +Merging a PR with Changesets will automatically create a PR with version bumps. That PR will be merged when releasing. ## React Native Quick SQLite Development -Testing live development changes to `@journeyapps/react-native-quick-sqlite` will not with with standard `yarn link` commands. Metro does not work well with symlinks https://github.com/facebook/metro/issues/286. +Testing live development changes to `@journeyapps/react-native-quick-sqlite` will not with with standard `yarn link` commands. Metro does not work well with symlinks . The process of releasing development packages for `@journeyapps/react-native-quick-sqlite` for each change can be tedious and slow. A faster (and hackier) method is to use [mtsl](https://www.npmjs.com/package/mtsl) which will watch and copy the package into this workspace's `node_modules`. ```bash npm install -g mtsl ``` + ```bash mtsl add -s "[source path to your react-native-quick-sqlite repo folder]" -d "[this workspaces root node_modules folder]"/@journeyapps/react-native-quick-sqlite ``` @@ -68,7 +73,6 @@ mtsl add -s "[source path to your react-native-quick-sqlite repo folder]" -d "[t mtsl start "[the id returned from step above]" ``` - ## Testing Supabase example app ``` bash @@ -76,7 +80,7 @@ cd apps/supabase-todolist ``` Test on either Android or iOS + ```bash yarn ios ``` - diff --git a/docs/.gitignore b/docs/.gitignore new file mode 100644 index 00000000..b2d6de30 --- /dev/null +++ b/docs/.gitignore @@ -0,0 +1,20 @@ +# Dependencies +/node_modules + +# Production +/build + +# Generated files +.docusaurus +.cache-loader + +# Misc +.DS_Store +.env.local +.env.development.local +.env.test.local +.env.production.local + +npm-debug.log* +yarn-debug.log* +yarn-error.log* diff --git a/docs/README.md b/docs/README.md new file mode 100644 index 00000000..aaba2fa1 --- /dev/null +++ b/docs/README.md @@ -0,0 +1,41 @@ +# Website + +This website is built using [Docusaurus 2](https://docusaurus.io/), a modern static website generator. + +### Installation + +``` +$ yarn +``` + +### Local Development + +``` +$ yarn start +``` + +This command starts a local development server and opens up a browser window. Most changes are reflected live without having to restart the server. + +### Build + +``` +$ yarn build +``` + +This command generates static content into the `build` directory and can be served using any static contents hosting service. + +### Deployment + +Using SSH: + +``` +$ USE_SSH=true yarn deploy +``` + +Not using SSH: + +``` +$ GIT_USER= yarn deploy +``` + +If you are using GitHub pages for hosting, this command is a convenient way to build the website and push to the `gh-pages` branch. diff --git a/docs/babel.config.js b/docs/babel.config.js new file mode 100644 index 00000000..e00595da --- /dev/null +++ b/docs/babel.config.js @@ -0,0 +1,3 @@ +module.exports = { + presets: [require.resolve('@docusaurus/core/lib/babel/preset')], +}; diff --git a/docs/docs/attachments-sdk/_category_.yml b/docs/docs/attachments-sdk/_category_.yml new file mode 100644 index 00000000..24a46026 --- /dev/null +++ b/docs/docs/attachments-sdk/_category_.yml @@ -0,0 +1 @@ +label: "API" \ No newline at end of file diff --git a/docs/docs/attachments-sdk/classes/AbstractAttachmentQueue.md b/docs/docs/attachments-sdk/classes/AbstractAttachmentQueue.md new file mode 100644 index 00000000..34767f4f --- /dev/null +++ b/docs/docs/attachments-sdk/classes/AbstractAttachmentQueue.md @@ -0,0 +1,514 @@ +--- +id: "AbstractAttachmentQueue" +title: "Class: AbstractAttachmentQueue" +sidebar_label: "AbstractAttachmentQueue" +sidebar_position: 0 +custom_edit_url: null +--- + +## Type parameters + +| Name | Type | +| :------ | :------ | +| `T` | extends [`AttachmentQueueOptions`](../interfaces/AttachmentQueueOptions.md) = [`AttachmentQueueOptions`](../interfaces/AttachmentQueueOptions.md) | + +## Constructors + +### constructor + +• **new AbstractAttachmentQueue**<`T`\>(`options`): [`AbstractAttachmentQueue`](AbstractAttachmentQueue.md)<`T`\> + +#### Type parameters + +| Name | Type | +| :------ | :------ | +| `T` | extends [`AttachmentQueueOptions`](../interfaces/AttachmentQueueOptions.md) = [`AttachmentQueueOptions`](../interfaces/AttachmentQueueOptions.md) | + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `options` | `T` | + +#### Returns + +[`AbstractAttachmentQueue`](AbstractAttachmentQueue.md)<`T`\> + +#### Defined in + +[powersync-attachments/src/AbstractAttachmentQueue.ts:40](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-attachments/src/AbstractAttachmentQueue.ts#L40) + +## Properties + +### downloadQueue + +• **downloadQueue**: `Set`<`string`\> + +#### Defined in + +[powersync-attachments/src/AbstractAttachmentQueue.ts:38](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-attachments/src/AbstractAttachmentQueue.ts#L38) + +___ + +### downloading + +• **downloading**: `boolean` + +#### Defined in + +[powersync-attachments/src/AbstractAttachmentQueue.ts:35](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-attachments/src/AbstractAttachmentQueue.ts#L35) + +___ + +### initialSync + +• **initialSync**: `boolean` + +#### Defined in + +[powersync-attachments/src/AbstractAttachmentQueue.ts:36](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-attachments/src/AbstractAttachmentQueue.ts#L36) + +___ + +### options + +• **options**: `T` + +#### Defined in + +[powersync-attachments/src/AbstractAttachmentQueue.ts:37](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-attachments/src/AbstractAttachmentQueue.ts#L37) + +___ + +### uploading + +• **uploading**: `boolean` + +#### Defined in + +[powersync-attachments/src/AbstractAttachmentQueue.ts:34](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-attachments/src/AbstractAttachmentQueue.ts#L34) + +## Accessors + +### powersync + +• `get` **powersync**(): `AbstractPowerSyncDatabase` + +#### Returns + +`AbstractPowerSyncDatabase` + +#### Defined in + +[powersync-attachments/src/AbstractAttachmentQueue.ts:67](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-attachments/src/AbstractAttachmentQueue.ts#L67) + +___ + +### storage + +• `get` **storage**(): [`StorageAdapter`](../interfaces/StorageAdapter.md) + +#### Returns + +[`StorageAdapter`](../interfaces/StorageAdapter.md) + +#### Defined in + +[powersync-attachments/src/AbstractAttachmentQueue.ts:71](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-attachments/src/AbstractAttachmentQueue.ts#L71) + +___ + +### storageDirectory + +• `get` **storageDirectory**(): `string` + +#### Returns + +`string` + +#### Defined in + +[powersync-attachments/src/AbstractAttachmentQueue.ts:79](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-attachments/src/AbstractAttachmentQueue.ts#L79) + +___ + +### table + +• `get` **table**(): `string` + +#### Returns + +`string` + +#### Defined in + +[powersync-attachments/src/AbstractAttachmentQueue.ts:75](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-attachments/src/AbstractAttachmentQueue.ts#L75) + +## Methods + +### attachmentIds + +▸ **attachmentIds**(): `AsyncIterable`<`string`[]\> + +Returns an async iterator that yields attachment IDs that need to be synced. +In most cases this will be a watch query + +Example: +for await (const result of powersync.watch('SELECT photo_id as id FROM todos WHERE photo_id IS NOT NULL', [])) { + yield result.rows?._array.map((r) => r.id) ?? []; +} + +#### Returns + +`AsyncIterable`<`string`[]\> + +#### Defined in + +[powersync-attachments/src/AbstractAttachmentQueue.ts:60](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-attachments/src/AbstractAttachmentQueue.ts#L60) + +___ + +### clearQueue + +▸ **clearQueue**(): `Promise`<`void`\> + +#### Returns + +`Promise`<`void`\> + +#### Defined in + +[powersync-attachments/src/AbstractAttachmentQueue.ts:463](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-attachments/src/AbstractAttachmentQueue.ts#L463) + +___ + +### delete + +▸ **delete**(`record`, `tx?`): `Promise`<`void`\> + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `record` | [`AttachmentRecord`](../interfaces/AttachmentRecord.md) | +| `tx?` | `Transaction` | + +#### Returns + +`Promise`<`void`\> + +#### Defined in + +[powersync-attachments/src/AbstractAttachmentQueue.ts:198](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-attachments/src/AbstractAttachmentQueue.ts#L198) + +___ + +### downloadRecord + +▸ **downloadRecord**(`record`): `Promise`<`boolean`\> + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `record` | [`AttachmentRecord`](../interfaces/AttachmentRecord.md) | + +#### Returns + +`Promise`<`boolean`\> + +#### Defined in + +[powersync-attachments/src/AbstractAttachmentQueue.ts:277](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-attachments/src/AbstractAttachmentQueue.ts#L277) + +___ + +### downloadRecords + +▸ **downloadRecords**(): `Promise`<`void`\> + +#### Returns + +`Promise`<`void`\> + +#### Defined in + +[powersync-attachments/src/AbstractAttachmentQueue.ts:410](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-attachments/src/AbstractAttachmentQueue.ts#L410) + +___ + +### expireCache + +▸ **expireCache**(): `Promise`<`void`\> + +#### Returns + +`Promise`<`void`\> + +#### Defined in + +[powersync-attachments/src/AbstractAttachmentQueue.ts:443](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-attachments/src/AbstractAttachmentQueue.ts#L443) + +___ + +### getIdsToDownload + +▸ **getIdsToDownload**(): `Promise`<`string`[]\> + +#### Returns + +`Promise`<`string`[]\> + +#### Defined in + +[powersync-attachments/src/AbstractAttachmentQueue.ts:375](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-attachments/src/AbstractAttachmentQueue.ts#L375) + +___ + +### getLocalUri + +▸ **getLocalUri**(`filename`): `string` + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `filename` | `string` | + +#### Returns + +`string` + +#### Defined in + +[powersync-attachments/src/AbstractAttachmentQueue.ts:439](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-attachments/src/AbstractAttachmentQueue.ts#L439) + +___ + +### getNextUploadRecord + +▸ **getNextUploadRecord**(): `Promise`<[`AttachmentRecord`](../interfaces/AttachmentRecord.md)\> + +#### Returns + +`Promise`<[`AttachmentRecord`](../interfaces/AttachmentRecord.md)\> + +#### Defined in + +[powersync-attachments/src/AbstractAttachmentQueue.ts:226](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-attachments/src/AbstractAttachmentQueue.ts#L226) + +___ + +### idsToDownload + +▸ **idsToDownload**(): `AsyncIterable`<`string`[]\> + +#### Returns + +`AsyncIterable`<`string`[]\> + +#### Defined in + +[powersync-attachments/src/AbstractAttachmentQueue.ts:388](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-attachments/src/AbstractAttachmentQueue.ts#L388) + +___ + +### idsToUpload + +▸ **idsToUpload**(): `AsyncIterable`<`string`[]\> + +#### Returns + +`AsyncIterable`<`string`[]\> + +#### Defined in + +[powersync-attachments/src/AbstractAttachmentQueue.ts:321](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-attachments/src/AbstractAttachmentQueue.ts#L321) + +___ + +### init + +▸ **init**(): `Promise`<`void`\> + +#### Returns + +`Promise`<`void`\> + +#### Defined in + +[powersync-attachments/src/AbstractAttachmentQueue.ts:83](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-attachments/src/AbstractAttachmentQueue.ts#L83) + +___ + +### newAttachmentRecord + +▸ **newAttachmentRecord**(`record?`): `Promise`<[`AttachmentRecord`](../interfaces/AttachmentRecord.md)\> + +Create a new AttachmentRecord, this gets called when the attachment id is not found in the database. + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `record?` | `Partial`<[`AttachmentRecord`](../interfaces/AttachmentRecord.md)\> | + +#### Returns + +`Promise`<[`AttachmentRecord`](../interfaces/AttachmentRecord.md)\> + +#### Defined in + +[powersync-attachments/src/AbstractAttachmentQueue.ts:65](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-attachments/src/AbstractAttachmentQueue.ts#L65) + +___ + +### record + +▸ **record**(`id`): `Promise`<[`AttachmentRecord`](../interfaces/AttachmentRecord.md)\> + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `id` | `string` | + +#### Returns + +`Promise`<[`AttachmentRecord`](../interfaces/AttachmentRecord.md)\> + +#### Defined in + +[powersync-attachments/src/AbstractAttachmentQueue.ts:178](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-attachments/src/AbstractAttachmentQueue.ts#L178) + +___ + +### saveToQueue + +▸ **saveToQueue**(`record`): `Promise`<[`AttachmentRecord`](../interfaces/AttachmentRecord.md)\> + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `record` | `Omit`<[`AttachmentRecord`](../interfaces/AttachmentRecord.md), ``"timestamp"``\> | + +#### Returns + +`Promise`<[`AttachmentRecord`](../interfaces/AttachmentRecord.md)\> + +#### Defined in + +[powersync-attachments/src/AbstractAttachmentQueue.ts:156](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-attachments/src/AbstractAttachmentQueue.ts#L156) + +___ + +### trigger + +▸ **trigger**(): `void` + +#### Returns + +`void` + +#### Defined in + +[powersync-attachments/src/AbstractAttachmentQueue.ts:98](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-attachments/src/AbstractAttachmentQueue.ts#L98) + +___ + +### update + +▸ **update**(`record`): `Promise`<`void`\> + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `record` | `Omit`<[`AttachmentRecord`](../interfaces/AttachmentRecord.md), ``"timestamp"``\> | + +#### Returns + +`Promise`<`void`\> + +#### Defined in + +[powersync-attachments/src/AbstractAttachmentQueue.ts:182](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-attachments/src/AbstractAttachmentQueue.ts#L182) + +___ + +### uploadAttachment + +▸ **uploadAttachment**(`record`): `Promise`<`boolean`\> + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `record` | [`AttachmentRecord`](../interfaces/AttachmentRecord.md) | + +#### Returns + +`Promise`<`boolean`\> + +#### Defined in + +[powersync-attachments/src/AbstractAttachmentQueue.ts:240](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-attachments/src/AbstractAttachmentQueue.ts#L240) + +___ + +### uploadRecords + +▸ **uploadRecords**(): `Promise`<`void`\> + +Returns immediately if another loop is in progress. + +#### Returns + +`Promise`<`void`\> + +#### Defined in + +[powersync-attachments/src/AbstractAttachmentQueue.ts:348](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-attachments/src/AbstractAttachmentQueue.ts#L348) + +___ + +### watchAttachmentIds + +▸ **watchAttachmentIds**(): `Promise`<`void`\> + +#### Returns + +`Promise`<`void`\> + +#### Defined in + +[powersync-attachments/src/AbstractAttachmentQueue.ts:104](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-attachments/src/AbstractAttachmentQueue.ts#L104) + +___ + +### watchDownloads + +▸ **watchDownloads**(): `Promise`<`void`\> + +#### Returns + +`Promise`<`void`\> + +#### Defined in + +[powersync-attachments/src/AbstractAttachmentQueue.ts:402](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-attachments/src/AbstractAttachmentQueue.ts#L402) + +___ + +### watchUploads + +▸ **watchUploads**(): `Promise`<`void`\> + +#### Returns + +`Promise`<`void`\> + +#### Defined in + +[powersync-attachments/src/AbstractAttachmentQueue.ts:337](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-attachments/src/AbstractAttachmentQueue.ts#L337) diff --git a/docs/docs/attachments-sdk/classes/AttachmentTable.md b/docs/docs/attachments-sdk/classes/AttachmentTable.md new file mode 100644 index 00000000..3dc3be1b --- /dev/null +++ b/docs/docs/attachments-sdk/classes/AttachmentTable.md @@ -0,0 +1,251 @@ +--- +id: "AttachmentTable" +title: "Class: AttachmentTable" +sidebar_label: "AttachmentTable" +sidebar_position: 0 +custom_edit_url: null +--- + +## Hierarchy + +- `Table` + + ↳ **`AttachmentTable`** + +## Constructors + +### constructor + +• **new AttachmentTable**(`options?`): [`AttachmentTable`](AttachmentTable.md) + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `options?` | [`AttachmentTableOptions`](../interfaces/AttachmentTableOptions.md) | + +#### Returns + +[`AttachmentTable`](AttachmentTable.md) + +#### Overrides + +Table.constructor + +#### Defined in + +[powersync-attachments/src/Schema.ts:29](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-attachments/src/Schema.ts#L29) + +## Properties + +### options + +• `Protected` **options**: `TableOptions` + +#### Inherited from + +Table.options + +#### Defined in + +powersync-sdk-common/lib/db/schema/Table.d.ts:12 + +## Accessors + +### columns + +• `get` **columns**(): `Column`[] + +#### Returns + +`Column`[] + +#### Inherited from + +Table.columns + +#### Defined in + +powersync-sdk-common/lib/db/schema/Table.d.ts:17 + +___ + +### indexes + +• `get` **indexes**(): `Index`[] + +#### Returns + +`Index`[] + +#### Inherited from + +Table.indexes + +#### Defined in + +powersync-sdk-common/lib/db/schema/Table.d.ts:18 + +___ + +### insertOnly + +• `get` **insertOnly**(): `boolean` + +#### Returns + +`boolean` + +#### Inherited from + +Table.insertOnly + +#### Defined in + +powersync-sdk-common/lib/db/schema/Table.d.ts:20 + +___ + +### internalName + +• `get` **internalName**(): `string` + +#### Returns + +`string` + +#### Inherited from + +Table.internalName + +#### Defined in + +powersync-sdk-common/lib/db/schema/Table.d.ts:21 + +___ + +### localOnly + +• `get` **localOnly**(): `boolean` + +#### Returns + +`boolean` + +#### Inherited from + +Table.localOnly + +#### Defined in + +powersync-sdk-common/lib/db/schema/Table.d.ts:19 + +___ + +### name + +• `get` **name**(): `string` + +#### Returns + +`string` + +#### Inherited from + +Table.name + +#### Defined in + +powersync-sdk-common/lib/db/schema/Table.d.ts:16 + +___ + +### validName + +• `get` **validName**(): `boolean` + +#### Returns + +`boolean` + +#### Inherited from + +Table.validName + +#### Defined in + +powersync-sdk-common/lib/db/schema/Table.d.ts:22 + +## Methods + +### toJSON + +▸ **toJSON**(): `Object` + +#### Returns + +`Object` + +| Name | Type | +| :------ | :------ | +| `columns` | \{ `name`: `string` ; `type`: `ColumnType` }[] | +| `indexes` | \{ `columns`: \{ `ascending`: `boolean` ; `name`: `string` ; `type`: `ColumnType` }[] ; `name`: `string` }[] | +| `insert_only` | `boolean` | +| `local_only` | `boolean` | +| `name` | `string` | + +#### Inherited from + +Table.toJSON + +#### Defined in + +powersync-sdk-common/lib/db/schema/Table.d.ts:23 + +___ + +### createInsertOnly + +▸ **createInsertOnly**(`options`): `Table` + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `options` | `TableOptions` | + +#### Returns + +`Table` + +#### Inherited from + +Table.createInsertOnly + +#### Defined in + +powersync-sdk-common/lib/db/schema/Table.d.ts:14 + +___ + +### createLocalOnly + +▸ **createLocalOnly**(`options`): `Table` + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `options` | `TableOptions` | + +#### Returns + +`Table` + +#### Inherited from + +Table.createLocalOnly + +#### Defined in + +powersync-sdk-common/lib/db/schema/Table.d.ts:13 diff --git a/docs/docs/attachments-sdk/classes/_category_.yml b/docs/docs/attachments-sdk/classes/_category_.yml new file mode 100644 index 00000000..55c7980a --- /dev/null +++ b/docs/docs/attachments-sdk/classes/_category_.yml @@ -0,0 +1,2 @@ +label: "Classes" +position: 3 \ No newline at end of file diff --git a/docs/docs/attachments-sdk/enums/AttachmentState.md b/docs/docs/attachments-sdk/enums/AttachmentState.md new file mode 100644 index 00000000..55b08e81 --- /dev/null +++ b/docs/docs/attachments-sdk/enums/AttachmentState.md @@ -0,0 +1,57 @@ +--- +id: "AttachmentState" +title: "Enumeration: AttachmentState" +sidebar_label: "AttachmentState" +sidebar_position: 0 +custom_edit_url: null +--- + +## Enumeration Members + +### ARCHIVED + +• **ARCHIVED** = ``4`` + +#### Defined in + +[powersync-attachments/src/Schema.ts:20](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-attachments/src/Schema.ts#L20) + +___ + +### QUEUED\_DOWNLOAD + +• **QUEUED\_DOWNLOAD** = ``2`` + +#### Defined in + +[powersync-attachments/src/Schema.ts:18](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-attachments/src/Schema.ts#L18) + +___ + +### QUEUED\_SYNC + +• **QUEUED\_SYNC** = ``0`` + +#### Defined in + +[powersync-attachments/src/Schema.ts:16](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-attachments/src/Schema.ts#L16) + +___ + +### QUEUED\_UPLOAD + +• **QUEUED\_UPLOAD** = ``1`` + +#### Defined in + +[powersync-attachments/src/Schema.ts:17](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-attachments/src/Schema.ts#L17) + +___ + +### SYNCED + +• **SYNCED** = ``3`` + +#### Defined in + +[powersync-attachments/src/Schema.ts:19](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-attachments/src/Schema.ts#L19) diff --git a/docs/docs/attachments-sdk/enums/EncodingType.md b/docs/docs/attachments-sdk/enums/EncodingType.md new file mode 100644 index 00000000..ddc5ba3a --- /dev/null +++ b/docs/docs/attachments-sdk/enums/EncodingType.md @@ -0,0 +1,27 @@ +--- +id: "EncodingType" +title: "Enumeration: EncodingType" +sidebar_label: "EncodingType" +sidebar_position: 0 +custom_edit_url: null +--- + +## Enumeration Members + +### Base64 + +• **Base64** = ``"base64"`` + +#### Defined in + +[powersync-attachments/src/StorageAdapter.ts:3](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-attachments/src/StorageAdapter.ts#L3) + +___ + +### UTF8 + +• **UTF8** = ``"utf8"`` + +#### Defined in + +[powersync-attachments/src/StorageAdapter.ts:2](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-attachments/src/StorageAdapter.ts#L2) diff --git a/docs/docs/attachments-sdk/enums/_category_.yml b/docs/docs/attachments-sdk/enums/_category_.yml new file mode 100644 index 00000000..1687a9e0 --- /dev/null +++ b/docs/docs/attachments-sdk/enums/_category_.yml @@ -0,0 +1,2 @@ +label: "Enumerations" +position: 2 \ No newline at end of file diff --git a/docs/docs/attachments-sdk/index.md b/docs/docs/attachments-sdk/index.md new file mode 100644 index 00000000..24dd5378 --- /dev/null +++ b/docs/docs/attachments-sdk/index.md @@ -0,0 +1,236 @@ +--- +id: "index" +title: "@journeyapps/powersync-attachments" +sidebar_label: "Readme" +sidebar_position: 0 +custom_edit_url: null +--- + +# @journeyapps/powersync-attachments + +A [PowerSync](https://powersync.co) library to manage attachments in TypeScript and React Native apps. + +Note: This package is currently in a beta release. + +## Installation + +**yarn** +```bash +yarn add @journeyapps/powersync-attachments +``` + +**npm** +```bash +npm install @journeyapps/powersync-attachments +``` + +## Usage + +The `AttachmentQueue` class is used to manage and sync attachments in your app. + +### Example + +In this example, the user captures photos when checklist items are completed as part of an inspection workflow. + +The schema for the `checklist` table: + +```javascript +const AppSchema = new Schema([ + new Table({ + name: 'checklists', + columns: [ + new Column({ name: 'photo_id', type: ColumnType.TEXT }), + new Column({ name: 'description', type: ColumnType.TEXT }), + new Column({ name: 'completed', type: ColumnType.INTEGER }), + new Column({ name: 'completed_at', type: ColumnType.TEXT }), + new Column({ name: 'completed_by', type: ColumnType.TEXT }) + ], + indexes: [ + new Index({ + name: 'inspections', + columns: [new IndexedColumn({ name: 'checklist_id' })] + }) + ] + }) +]); +``` + +### Steps to implement + +1. Create a new class `AttachmentQueue` that extends `AbstractAttachmentQueue` from `@journeyapps/powersync-attachments`. +```javascript +import { AbstractAttachmentQueue } from '@journeyapps/powersync-attachments'; + +export class AttachmentQueue extends AbstractAttachmentQueue { + +} +``` + +2. Implement `attachmentIds`, an `AsyncIterator` method to return an array of `string` values of IDs that relate to attachments in your app. We recommend using `PowerSync`'s `watch` query to return the all IDs of attachments in your app. + + In this example, we query all photos that have been captured as part of an inspection and map these to an array of `string` values. + +```javascript +import { AbstractAttachmentQueue } from '@journeyapps/powersync-attachments'; + +export class AttachmentQueue extends AbstractAttachmentQueue { + async *attachmentIds() { + for await (const result of this.powersync.watch( + `SELECT photo_id as id FROM checklists WHERE photo_id IS NOT NULL`, + [] + )) { + yield result.rows?._array.map((r) => r.id) ?? []; + } + } +} +``` + +3. Implement `newAttachmentRecord` to return an object that represents the attachment record in your app. + + In this example we always work with `JPEG` images, but you can use any media type that is supported by your app and storage solution. Note: we are set the state to `QUEUED_UPLOAD` when creating a new photo record which assumes that the photo data is already on the device. + +```javascript +import { AbstractAttachmentQueue } from '@journeyapps/powersync-attachments'; + +export class AttachmentQueue extends AbstractAttachmentQueue { + // ... + async newAttachmentRecord(record) { + const photoId = record?.id ?? uuid(); + const filename = record?.filename ?? `${photoId}.jpg`; + return { + id: photoId, + filename, + media_type: 'image/jpeg', + state: AttachmentState.QUEUED_UPLOAD, + ...record + }; + } +} +``` + +4. Add an `AttachmentTable` to your app's PowerSync Schema: + +```javascript +import { AttachmentTable } from '@journeyapps/powersync-attachments'; + +const AppSchema = new Schema([ + // ... other tables + new AttachmentTable() +]); +``` + +In addition to `Table` options, the `AttachmentTable` can optionally be configured with the following options: + +| Option | Description | Default | +|---------------------|---------------------------------------------------------------------------------|-------------------------------| +| `name` | The name of the table | `attachments` | +| `additionalColumns` | An array of addition `Column` objects added to the default columns in the table | See below for default columns | + +The default columns in `AttachmentTable`: + +| Column Name | Type | Description | +|--------------|-----------|-------------------------------------------------------------------| +| `id` | `TEXT` | The ID of the attachment record | +| `filename` | `TEXT` | The filename of the attachment | +| `media_type` | `TEXT` | The media type of the attachment | +| `state` | `INTEGER` | The state of the attachment, one of `AttachmentState` enum values | +| `timestamp` | `INTEGER` | The timestamp of last update to the attachment record | +| `size` | `INTEGER` | The size of the attachment in bytes | + +5. To instantiate an `AttachmentQueue`, one needs to provide an instance of `AbstractPowerSyncDatabase` from PowerSync and an instance of `StorageAdapter`. +See the `StorageAdapter` interface definition [here](./src/StorageAdapter.ts). + +6. Instantiate a new `AttachmentQueue` and call `init()` to start syncing attachments. Our example, uses a `StorageAdapter` that integrates with Supabase Storage. + +```javascript +this.storage = this.supabaseConnector.storage; +this.powersync = factory.getInstance(); + +this.attachmentQueue = new AttachmentQueue({ + powersync: this.powersync, + storage: this.storage +}); + +// Initialize and connect PowerSync ... +// Then initialize the attachment queue +await this.attachmentQueue.init(); +``` + +7. Finally, to create an attachment and add it to the queue, call `saveToQueue()`. + + In our example we added a `savePhoto()` method to our `AttachmentQueue` class, that does this: + +```javascript + +export class AttachmentQueue extends AbstractAttachmentQueue { + // ... + async savePhoto(base64Data) { + const photoAttachment = await this.newAttachmentRecord(); + photoAttachment.local_uri = this.getLocalUri(photoAttachment.filename); + await this.storage.writeFile(photoAttachment.local_uri, base64Data, { encoding: 'base64' }); + + return this.saveToQueue(photoAttachment); + } + +} +``` + +# Implementation details + +## Attachment State + +The `AttachmentQueue` class manages attachments in your app by tracking their state. + +The state of an attachment can be one of the following: + +| State | Description | +|-------------------|-------------------------------------------------------------------------------| +| `QUEUED_SYNC` | Check if the attachment needs to be uploaded or downloaded | +| `QUEUED_UPLOAD` | The attachment has been queued for upload to the cloud storage | +| `QUEUED_DOWNLOAD` | The attachment has been queued for download from the cloud storage | +| `SYNCED` | The attachment has been synced | +| `ARCHIVED` | The attachment has been orphaned, i.e. the associated record has been deleted | + +## Initial sync + +Upon initializing the `AttachmentQueue`, an initial sync of attachments will take place if the `performInitialSync` is set to true. +Any `AttachmentRecord` with `id` in first set of IDs retrieved from the watch query will be marked as `QUEUED_SYNC`, and these records will be rechecked to see if they need to be uploaded or downloaded. + +## Syncing attachments + +The `AttachmentQueue` sets up two watch queries on the `attachments` table, one for records in `QUEUED_UPLOAD` state and one for `QUEUED_DOWNLOAD` state. + +In addition to watching for changes, the `AttachmentQueue` also triggers a sync every few seconds. This will retry any failed uploads/downloads, in particular after the app was offline. + +By default, this is every 30 seconds, but can be configured by setting `syncInterval` in the `AttachmentQueue` constructor options, or disabled by setting the interval to `0`. + +### Uploading + +- An `AttachmentRecord` is created or updated with a state of `QUEUED_UPLOAD`. +- The `AttachmentQueue` picks this up and upon successful upload to Supabase, sets the state to `SYNCED`. +- If the upload is not successful, the record remains in `QUEUED_UPLOAD` state and uploading will be retried when syncing triggers again. + +### Downloading + +- An `AttachmentRecord` is created or updated with `QUEUED_DOWNLOAD` state. +- The watch query adds the `id` into a queue of IDs to download and triggers the download process +- This checks whether the photo is already on the device and if so, skips downloading. +- If the photo is not on the device, it is downloaded from cloud storage. +- Writes file to the user's local storage. +- If this is successful, update the `AttachmentRecord` state to `SYNCED`. +- If any of these fail, the download is retried in the next sync trigger. + +### Deleting attachments + +When an attachment is deleted by a user action or cache expiration: +- Related `AttachmentRecord` is removed from attachments table. +- Local file (if exists) is deleted. +- File on cloud storage is deleted. + +### Expire Cache + +When PowerSync removes a record, as a result of coming back online or conflict resolution for instance: +- Any associated `AttachmentRecord` is orphaned. +- On the next sync trigger, the `AttachmentQueue` sets all records that are orphaned to `ARCHIVED` state. +- By default, the `AttachmentQueue` only keeps the last `100` attachment records and then expires the rest. +- This can be configured by setting `cacheLimit` in the `AttachmentQueue` constructor options. diff --git a/docs/docs/attachments-sdk/interfaces/AttachmentQueueOptions.md b/docs/docs/attachments-sdk/interfaces/AttachmentQueueOptions.md new file mode 100644 index 00000000..e8b176a0 --- /dev/null +++ b/docs/docs/attachments-sdk/interfaces/AttachmentQueueOptions.md @@ -0,0 +1,75 @@ +--- +id: "AttachmentQueueOptions" +title: "Interface: AttachmentQueueOptions" +sidebar_label: "AttachmentQueueOptions" +sidebar_position: 0 +custom_edit_url: null +--- + +## Properties + +### attachmentDirectoryName + +• `Optional` **attachmentDirectoryName**: `string` + +The name of the directory where attachments are stored on the device, not the full path + +#### Defined in + +[powersync-attachments/src/AbstractAttachmentQueue.ts:19](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-attachments/src/AbstractAttachmentQueue.ts#L19) + +___ + +### cacheLimit + +• `Optional` **cacheLimit**: `number` + +How many attachments to keep in the cache + +#### Defined in + +[powersync-attachments/src/AbstractAttachmentQueue.ts:15](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-attachments/src/AbstractAttachmentQueue.ts#L15) + +___ + +### performInitialSync + +• `Optional` **performInitialSync**: `boolean` + +Whether to mark the initial watched attachment IDs to be synced + +#### Defined in + +[powersync-attachments/src/AbstractAttachmentQueue.ts:23](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-attachments/src/AbstractAttachmentQueue.ts#L23) + +___ + +### powersync + +• **powersync**: `AbstractPowerSyncDatabase` + +#### Defined in + +[powersync-attachments/src/AbstractAttachmentQueue.ts:6](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-attachments/src/AbstractAttachmentQueue.ts#L6) + +___ + +### storage + +• **storage**: [`StorageAdapter`](StorageAdapter.md) + +#### Defined in + +[powersync-attachments/src/AbstractAttachmentQueue.ts:7](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-attachments/src/AbstractAttachmentQueue.ts#L7) + +___ + +### syncInterval + +• `Optional` **syncInterval**: `number` + +How often to check for new attachments to sync, in milliseconds. Set to 0 or undefined to disable. + +#### Defined in + +[powersync-attachments/src/AbstractAttachmentQueue.ts:11](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-attachments/src/AbstractAttachmentQueue.ts#L11) diff --git a/docs/docs/attachments-sdk/interfaces/AttachmentRecord.md b/docs/docs/attachments-sdk/interfaces/AttachmentRecord.md new file mode 100644 index 00000000..4116b4dc --- /dev/null +++ b/docs/docs/attachments-sdk/interfaces/AttachmentRecord.md @@ -0,0 +1,77 @@ +--- +id: "AttachmentRecord" +title: "Interface: AttachmentRecord" +sidebar_label: "AttachmentRecord" +sidebar_position: 0 +custom_edit_url: null +--- + +## Properties + +### filename + +• **filename**: `string` + +#### Defined in + +[powersync-attachments/src/Schema.ts:7](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-attachments/src/Schema.ts#L7) + +___ + +### id + +• **id**: `string` + +#### Defined in + +[powersync-attachments/src/Schema.ts:6](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-attachments/src/Schema.ts#L6) + +___ + +### local\_uri + +• `Optional` **local\_uri**: `string` + +#### Defined in + +[powersync-attachments/src/Schema.ts:8](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-attachments/src/Schema.ts#L8) + +___ + +### media\_type + +• `Optional` **media\_type**: `string` + +#### Defined in + +[powersync-attachments/src/Schema.ts:10](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-attachments/src/Schema.ts#L10) + +___ + +### size + +• `Optional` **size**: `number` + +#### Defined in + +[powersync-attachments/src/Schema.ts:9](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-attachments/src/Schema.ts#L9) + +___ + +### state + +• **state**: [`AttachmentState`](../enums/AttachmentState.md) + +#### Defined in + +[powersync-attachments/src/Schema.ts:12](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-attachments/src/Schema.ts#L12) + +___ + +### timestamp + +• `Optional` **timestamp**: `number` + +#### Defined in + +[powersync-attachments/src/Schema.ts:11](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-attachments/src/Schema.ts#L11) diff --git a/docs/docs/attachments-sdk/interfaces/AttachmentTableOptions.md b/docs/docs/attachments-sdk/interfaces/AttachmentTableOptions.md new file mode 100644 index 00000000..115ffaf8 --- /dev/null +++ b/docs/docs/attachments-sdk/interfaces/AttachmentTableOptions.md @@ -0,0 +1,75 @@ +--- +id: "AttachmentTableOptions" +title: "Interface: AttachmentTableOptions" +sidebar_label: "AttachmentTableOptions" +sidebar_position: 0 +custom_edit_url: null +--- + +## Hierarchy + +- `Omit`<`TableOptions`, ``"name"`` \| ``"columns"``\> + + ↳ **`AttachmentTableOptions`** + +## Properties + +### additionalColumns + +• `Optional` **additionalColumns**: `Column`[] + +#### Defined in + +[powersync-attachments/src/Schema.ts:25](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-attachments/src/Schema.ts#L25) + +___ + +### indexes + +• `Optional` **indexes**: `Index`[] + +#### Inherited from + +Omit.indexes + +#### Defined in + +powersync-sdk-common/lib/db/schema/Table.d.ts:6 + +___ + +### insertOnly + +• `Optional` **insertOnly**: `boolean` + +#### Inherited from + +Omit.insertOnly + +#### Defined in + +powersync-sdk-common/lib/db/schema/Table.d.ts:8 + +___ + +### localOnly + +• `Optional` **localOnly**: `boolean` + +#### Inherited from + +Omit.localOnly + +#### Defined in + +powersync-sdk-common/lib/db/schema/Table.d.ts:7 + +___ + +### name + +• `Optional` **name**: `string` + +#### Defined in + +[powersync-attachments/src/Schema.ts:24](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-attachments/src/Schema.ts#L24) diff --git a/docs/docs/attachments-sdk/interfaces/StorageAdapter.md b/docs/docs/attachments-sdk/interfaces/StorageAdapter.md new file mode 100644 index 00000000..f7994da5 --- /dev/null +++ b/docs/docs/attachments-sdk/interfaces/StorageAdapter.md @@ -0,0 +1,196 @@ +--- +id: "StorageAdapter" +title: "Interface: StorageAdapter" +sidebar_label: "StorageAdapter" +sidebar_position: 0 +custom_edit_url: null +--- + +## Methods + +### copyFile + +▸ **copyFile**(`sourceUri`, `targetUri`): `Promise`<`void`\> + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `sourceUri` | `string` | +| `targetUri` | `string` | + +#### Returns + +`Promise`<`void`\> + +#### Defined in + +[powersync-attachments/src/StorageAdapter.ts:32](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-attachments/src/StorageAdapter.ts#L32) + +___ + +### deleteFile + +▸ **deleteFile**(`uri`, `options?`): `Promise`<`void`\> + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `uri` | `string` | +| `options?` | `Object` | +| `options.filename?` | `string` | + +#### Returns + +`Promise`<`void`\> + +#### Defined in + +[powersync-attachments/src/StorageAdapter.ts:26](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-attachments/src/StorageAdapter.ts#L26) + +___ + +### downloadFile + +▸ **downloadFile**(`filePath`): `Promise`<`Blob`\> + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `filePath` | `string` | + +#### Returns + +`Promise`<`Blob`\> + +#### Defined in + +[powersync-attachments/src/StorageAdapter.ts:13](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-attachments/src/StorageAdapter.ts#L13) + +___ + +### fileExists + +▸ **fileExists**(`fileURI`): `Promise`<`boolean`\> + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `fileURI` | `string` | + +#### Returns + +`Promise`<`boolean`\> + +#### Defined in + +[powersync-attachments/src/StorageAdapter.ts:28](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-attachments/src/StorageAdapter.ts#L28) + +___ + +### getUserStorageDirectory + +▸ **getUserStorageDirectory**(): `string` + +Returns the directory where user data is stored. +Should end with a '/' + +#### Returns + +`string` + +#### Defined in + +[powersync-attachments/src/StorageAdapter.ts:38](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-attachments/src/StorageAdapter.ts#L38) + +___ + +### makeDir + +▸ **makeDir**(`uri`): `Promise`<`void`\> + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `uri` | `string` | + +#### Returns + +`Promise`<`void`\> + +#### Defined in + +[powersync-attachments/src/StorageAdapter.ts:30](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-attachments/src/StorageAdapter.ts#L30) + +___ + +### readFile + +▸ **readFile**(`fileURI`, `options?`): `Promise`<`ArrayBuffer`\> + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `fileURI` | `string` | +| `options?` | `Object` | +| `options.encoding?` | [`EncodingType`](../enums/EncodingType.md) | +| `options.mediaType?` | `string` | + +#### Returns + +`Promise`<`ArrayBuffer`\> + +#### Defined in + +[powersync-attachments/src/StorageAdapter.ts:21](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-attachments/src/StorageAdapter.ts#L21) + +___ + +### uploadFile + +▸ **uploadFile**(`filePath`, `data`, `options?`): `Promise`<`void`\> + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `filePath` | `string` | +| `data` | `ArrayBuffer` | +| `options?` | `Object` | +| `options.mediaType?` | `string` | + +#### Returns + +`Promise`<`void`\> + +#### Defined in + +[powersync-attachments/src/StorageAdapter.ts:7](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-attachments/src/StorageAdapter.ts#L7) + +___ + +### writeFile + +▸ **writeFile**(`fileURI`, `base64Data`, `options?`): `Promise`<`void`\> + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `fileURI` | `string` | +| `base64Data` | `string` | +| `options?` | `Object` | +| `options.encoding?` | [`EncodingType`](../enums/EncodingType.md) | + +#### Returns + +`Promise`<`void`\> + +#### Defined in + +[powersync-attachments/src/StorageAdapter.ts:15](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-attachments/src/StorageAdapter.ts#L15) diff --git a/docs/docs/attachments-sdk/interfaces/_category_.yml b/docs/docs/attachments-sdk/interfaces/_category_.yml new file mode 100644 index 00000000..43bec88c --- /dev/null +++ b/docs/docs/attachments-sdk/interfaces/_category_.yml @@ -0,0 +1,2 @@ +label: "Interfaces" +position: 4 \ No newline at end of file diff --git a/docs/docs/attachments-sdk/modules.md b/docs/docs/attachments-sdk/modules.md new file mode 100644 index 00000000..145be758 --- /dev/null +++ b/docs/docs/attachments-sdk/modules.md @@ -0,0 +1,44 @@ +--- +id: "modules" +title: "@journeyapps/powersync-attachments" +sidebar_label: "Exports" +sidebar_position: 0.5 +custom_edit_url: null +--- + +## Enumerations + +- [AttachmentState](enums/AttachmentState.md) +- [EncodingType](enums/EncodingType.md) + +## Classes + +- [AbstractAttachmentQueue](classes/AbstractAttachmentQueue.md) +- [AttachmentTable](classes/AttachmentTable.md) + +## Interfaces + +- [AttachmentQueueOptions](interfaces/AttachmentQueueOptions.md) +- [AttachmentRecord](interfaces/AttachmentRecord.md) +- [AttachmentTableOptions](interfaces/AttachmentTableOptions.md) +- [StorageAdapter](interfaces/StorageAdapter.md) + +## Variables + +### ATTACHMENT\_TABLE + +• `Const` **ATTACHMENT\_TABLE**: ``"attachments"`` + +#### Defined in + +[powersync-attachments/src/Schema.ts:3](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-attachments/src/Schema.ts#L3) + +___ + +### DEFAULT\_ATTACHMENT\_QUEUE\_OPTIONS + +• `Const` **DEFAULT\_ATTACHMENT\_QUEUE\_OPTIONS**: `Partial`<[`AttachmentQueueOptions`](interfaces/AttachmentQueueOptions.md)\> + +#### Defined in + +[powersync-attachments/src/AbstractAttachmentQueue.ts:26](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-attachments/src/AbstractAttachmentQueue.ts#L26) diff --git a/docs/docs/common-sdk/_category_.yml b/docs/docs/common-sdk/_category_.yml new file mode 100644 index 00000000..24a46026 --- /dev/null +++ b/docs/docs/common-sdk/_category_.yml @@ -0,0 +1 @@ +label: "API" \ No newline at end of file diff --git a/docs/docs/common-sdk/classes/AbstractPowerSyncDatabase.md b/docs/docs/common-sdk/classes/AbstractPowerSyncDatabase.md new file mode 100644 index 00000000..cfbeddad --- /dev/null +++ b/docs/docs/common-sdk/classes/AbstractPowerSyncDatabase.md @@ -0,0 +1,819 @@ +--- +id: "AbstractPowerSyncDatabase" +title: "Class: AbstractPowerSyncDatabase" +sidebar_label: "AbstractPowerSyncDatabase" +sidebar_position: 0 +custom_edit_url: null +--- + +## Hierarchy + +- [`BaseObserver`](BaseObserver.md)<[`PowerSyncDBListener`](../interfaces/PowerSyncDBListener.md)\> + + ↳ **`AbstractPowerSyncDatabase`** + +## Constructors + +### constructor + +• **new AbstractPowerSyncDatabase**(`options`): [`AbstractPowerSyncDatabase`](AbstractPowerSyncDatabase.md) + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `options` | [`PowerSyncDatabaseOptions`](../interfaces/PowerSyncDatabaseOptions.md) | + +#### Returns + +[`AbstractPowerSyncDatabase`](AbstractPowerSyncDatabase.md) + +#### Overrides + +[BaseObserver](BaseObserver.md).[constructor](BaseObserver.md#constructor) + +#### Defined in + +[client/AbstractPowerSyncDatabase.ts:77](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/AbstractPowerSyncDatabase.ts#L77) + +## Properties + +### \_isReadyPromise + +• `Protected` **\_isReadyPromise**: `Promise`<`void`\> + +#### Defined in + +[client/AbstractPowerSyncDatabase.ts:75](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/AbstractPowerSyncDatabase.ts#L75) + +___ + +### abortController + +• `Private` **abortController**: `AbortController` + +#### Defined in + +[client/AbstractPowerSyncDatabase.ts:72](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/AbstractPowerSyncDatabase.ts#L72) + +___ + +### bucketStorageAdapter + +• `Protected` **bucketStorageAdapter**: [`BucketStorageAdapter`](../interfaces/BucketStorageAdapter.md) + +#### Defined in + +[client/AbstractPowerSyncDatabase.ts:73](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/AbstractPowerSyncDatabase.ts#L73) + +___ + +### closed + +• **closed**: `boolean` + +#### Defined in + +[client/AbstractPowerSyncDatabase.ts:65](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/AbstractPowerSyncDatabase.ts#L65) + +___ + +### currentStatus + +• `Optional` **currentStatus**: [`SyncStatus`](SyncStatus.md) + +#### Defined in + +[client/AbstractPowerSyncDatabase.ts:68](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/AbstractPowerSyncDatabase.ts#L68) + +___ + +### listeners + +• `Protected` **listeners**: `Object` + +#### Index signature + +▪ [id: `string`]: `Partial`<`T`\> + +#### Inherited from + +[BaseObserver](BaseObserver.md).[listeners](BaseObserver.md#listeners) + +#### Defined in + +[utils/BaseObserver.ts:12](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/utils/BaseObserver.ts#L12) + +___ + +### options + +• `Protected` **options**: [`PowerSyncDatabaseOptions`](../interfaces/PowerSyncDatabaseOptions.md) + +#### Defined in + +[client/AbstractPowerSyncDatabase.ts:77](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/AbstractPowerSyncDatabase.ts#L77) + +___ + +### ready + +• **ready**: `boolean` + +#### Defined in + +[client/AbstractPowerSyncDatabase.ts:66](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/AbstractPowerSyncDatabase.ts#L66) + +___ + +### sdkVersion + +• **sdkVersion**: `string` + +#### Defined in + +[client/AbstractPowerSyncDatabase.ts:70](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/AbstractPowerSyncDatabase.ts#L70) + +___ + +### syncStatusListenerDisposer + +• `Private` `Optional` **syncStatusListenerDisposer**: () => `void` + +#### Type declaration + +▸ (): `void` + +##### Returns + +`void` + +#### Defined in + +[client/AbstractPowerSyncDatabase.ts:74](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/AbstractPowerSyncDatabase.ts#L74) + +___ + +### syncStreamImplementation + +• `Optional` **syncStreamImplementation**: [`AbstractStreamingSyncImplementation`](AbstractStreamingSyncImplementation.md) + +#### Defined in + +[client/AbstractPowerSyncDatabase.ts:69](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/AbstractPowerSyncDatabase.ts#L69) + +___ + +### transactionMutex + +▪ `Static` `Protected` **transactionMutex**: `Mutex` + +Transactions should be queued in the DBAdapter, but we also want to prevent +calls to `.execute` while an async transaction is running. + +#### Defined in + +[client/AbstractPowerSyncDatabase.ts:63](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/AbstractPowerSyncDatabase.ts#L63) + +## Accessors + +### connected + +• `get` **connected**(): `boolean` + +#### Returns + +`boolean` + +#### Defined in + +[client/AbstractPowerSyncDatabase.ts:97](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/AbstractPowerSyncDatabase.ts#L97) + +___ + +### database + +• `get` **database**(): [`DBAdapter`](../interfaces/DBAdapter.md) + +#### Returns + +[`DBAdapter`](../interfaces/DBAdapter.md) + +#### Defined in + +[client/AbstractPowerSyncDatabase.ts:93](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/AbstractPowerSyncDatabase.ts#L93) + +___ + +### schema + +• `get` **schema**(): [`Schema`](Schema.md) + +#### Returns + +[`Schema`](Schema.md) + +#### Defined in + +[client/AbstractPowerSyncDatabase.ts:89](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/AbstractPowerSyncDatabase.ts#L89) + +## Methods + +### \_initialize + +▸ **_initialize**(): `Promise`<`void`\> + +Allows for extended implementations to execute custom initialization +logic as part of the total init process + +#### Returns + +`Promise`<`void`\> + +#### Defined in + +[client/AbstractPowerSyncDatabase.ts:122](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/AbstractPowerSyncDatabase.ts#L122) + +___ + +### close + +▸ **close**(): `Promise`<`void`\> + +#### Returns + +`Promise`<`void`\> + +#### Defined in + +[client/AbstractPowerSyncDatabase.ts:210](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/AbstractPowerSyncDatabase.ts#L210) + +___ + +### connect + +▸ **connect**(`connector`): `Promise`<`void`\> + +Connects to stream of events from PowerSync instance + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `connector` | [`PowerSyncBackendConnector`](../interfaces/PowerSyncBackendConnector.md) | + +#### Returns + +`Promise`<`void`\> + +#### Defined in + +[client/AbstractPowerSyncDatabase.ts:149](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/AbstractPowerSyncDatabase.ts#L149) + +___ + +### disconnect + +▸ **disconnect**(): `Promise`<`void`\> + +#### Returns + +`Promise`<`void`\> + +#### Defined in + +[client/AbstractPowerSyncDatabase.ts:168](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/AbstractPowerSyncDatabase.ts#L168) + +___ + +### disconnectAndClear + +▸ **disconnectAndClear**(): `Promise`<`void`\> + +Disconnect and clear the database. + Use this when logging out. + The database can still be queried after this is called, but the tables + would be empty. + +#### Returns + +`Promise`<`void`\> + +#### Defined in + +[client/AbstractPowerSyncDatabase.ts:180](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/AbstractPowerSyncDatabase.ts#L180) + +___ + +### execute + +▸ **execute**(`sql`, `parameters?`): `Promise`<[`QueryResult`](../interfaces/QueryResult.md)\> + +Execute a statement and optionally return results + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `sql` | `string` | +| `parameters?` | `any`[] | + +#### Returns + +`Promise`<[`QueryResult`](../interfaces/QueryResult.md)\> + +#### Defined in + +[client/AbstractPowerSyncDatabase.ts:340](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/AbstractPowerSyncDatabase.ts#L340) + +___ + +### executeReadOnly + +▸ **executeReadOnly**(`sql`, `params`): `Promise`<[`QueryResult`](../interfaces/QueryResult.md)\> + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `sql` | `string` | +| `params` | `any`[] | + +#### Returns + +`Promise`<[`QueryResult`](../interfaces/QueryResult.md)\> + +#### Defined in + +[client/AbstractPowerSyncDatabase.ts:496](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/AbstractPowerSyncDatabase.ts#L496) + +___ + +### generateBucketStorageAdapter + +▸ **generateBucketStorageAdapter**(): [`BucketStorageAdapter`](../interfaces/BucketStorageAdapter.md) + +#### Returns + +[`BucketStorageAdapter`](../interfaces/BucketStorageAdapter.md) + +#### Defined in + +[client/AbstractPowerSyncDatabase.ts:105](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/AbstractPowerSyncDatabase.ts#L105) + +___ + +### generateSyncStreamImplementation + +▸ **generateSyncStreamImplementation**(`connector`): [`AbstractStreamingSyncImplementation`](AbstractStreamingSyncImplementation.md) + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `connector` | [`PowerSyncBackendConnector`](../interfaces/PowerSyncBackendConnector.md) | + +#### Returns + +[`AbstractStreamingSyncImplementation`](AbstractStreamingSyncImplementation.md) + +#### Defined in + +[client/AbstractPowerSyncDatabase.ts:101](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/AbstractPowerSyncDatabase.ts#L101) + +___ + +### get + +▸ **get**<`T`\>(`sql`, `parameters?`): `Promise`<`T`\> + +Execute a read-only query and return the first result, error if the ResultSet is empty. + +#### Type parameters + +| Name | +| :------ | +| `T` | + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `sql` | `string` | +| `parameters?` | `any`[] | + +#### Returns + +`Promise`<`T`\> + +#### Defined in + +[client/AbstractPowerSyncDatabase.ts:364](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/AbstractPowerSyncDatabase.ts#L364) + +___ + +### getAll + +▸ **getAll**<`T`\>(`sql`, `parameters?`): `Promise`<`T`[]\> + +Execute a read-only query and return results + +#### Type parameters + +| Name | +| :------ | +| `T` | + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `sql` | `string` | +| `parameters?` | `any`[] | + +#### Returns + +`Promise`<`T`[]\> + +#### Defined in + +[client/AbstractPowerSyncDatabase.ts:348](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/AbstractPowerSyncDatabase.ts#L348) + +___ + +### getCrudBatch + +▸ **getCrudBatch**(`limit`): `Promise`<[`CrudBatch`](CrudBatch.md)\> + +Get a batch of crud data to upload. + +Returns null if there is no data to upload. + +Use this from the [PowerSyncBackendConnector.uploadData]` callback. + +Once the data have been successfully uploaded, call [CrudBatch.complete] before +requesting the next batch. + +Use [limit] to specify the maximum number of updates to return in a single +batch. + +This method does include transaction ids in the result, but does not group +data by transaction. One batch may contain data from multiple transactions, +and a single transaction may be split over multiple batches. + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `limit` | `number` | + +#### Returns + +`Promise`<[`CrudBatch`](CrudBatch.md)\> + +#### Defined in + +[client/AbstractPowerSyncDatabase.ts:252](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/AbstractPowerSyncDatabase.ts#L252) + +___ + +### getNextCrudTransaction + +▸ **getNextCrudTransaction**(): `Promise`<[`CrudTransaction`](CrudTransaction.md)\> + +Get the next recorded transaction to upload. + +Returns null if there is no data to upload. + +Use this from the [PowerSyncBackendConnector.uploadData]` callback. + +Once the data have been successfully uploaded, call [CrudTransaction.complete] before +requesting the next transaction. + +Unlike [getCrudBatch], this only returns data from a single transaction at a time. +All data for the transaction is loaded into memory. + +#### Returns + +`Promise`<[`CrudTransaction`](CrudTransaction.md)\> + +#### Defined in + +[client/AbstractPowerSyncDatabase.ts:296](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/AbstractPowerSyncDatabase.ts#L296) + +___ + +### getOptional + +▸ **getOptional**<`T`\>(`sql`, `parameters?`): `Promise`<`T`\> + +Execute a read-only query and return the first result, or null if the ResultSet is empty. + +#### Type parameters + +| Name | +| :------ | +| `T` | + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `sql` | `string` | +| `parameters?` | `any`[] | + +#### Returns + +`Promise`<`T`\> + +#### Defined in + +[client/AbstractPowerSyncDatabase.ts:356](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/AbstractPowerSyncDatabase.ts#L356) + +___ + +### getUploadQueueStats + +▸ **getUploadQueueStats**(`includeSize?`): `Promise`<[`UploadQueueStats`](UploadQueueStats.md)\> + +Get upload queue size estimate and count. + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `includeSize?` | `boolean` | + +#### Returns + +`Promise`<[`UploadQueueStats`](UploadQueueStats.md)\> + +#### Defined in + +[client/AbstractPowerSyncDatabase.ts:220](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/AbstractPowerSyncDatabase.ts#L220) + +___ + +### init + +▸ **init**(): `Promise`<`void`\> + +Wait for initialization to complete. +While initializing is automatic, this helps to catch and report initialization errors. + +#### Returns + +`Promise`<`void`\> + +#### Defined in + +[client/AbstractPowerSyncDatabase.ts:142](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/AbstractPowerSyncDatabase.ts#L142) + +___ + +### initialize + +▸ **initialize**(): `Promise`<`void`\> + +Entry point for executing initialization logic. +This is to be automatically executed in the constructor. + +#### Returns + +`Promise`<`void`\> + +#### Defined in + +[client/AbstractPowerSyncDatabase.ts:128](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/AbstractPowerSyncDatabase.ts#L128) + +___ + +### iterateListeners + +▸ **iterateListeners**(`cb`): `void` + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `cb` | (`listener`: `Partial`<[`PowerSyncDBListener`](../interfaces/PowerSyncDBListener.md)\>) => `any` | + +#### Returns + +`void` + +#### Inherited from + +[BaseObserver](BaseObserver.md).[iterateListeners](BaseObserver.md#iteratelisteners) + +#### Defined in + +[utils/BaseObserver.ts:26](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/utils/BaseObserver.ts#L26) + +___ + +### onChange + +▸ **onChange**(`options?`): `AsyncIterable`<[`WatchOnChangeEvent`](../interfaces/WatchOnChangeEvent.md)\> + +Create a Stream of changes to any of the specified tables. + +This is preferred over [watch] when multiple queries need to be performed +together when data is changed. + +Note, do not declare this as `async *onChange` as it will not work in React Native + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `options?` | [`SQLWatchOptions`](../interfaces/SQLWatchOptions.md) | + +#### Returns + +`AsyncIterable`<[`WatchOnChangeEvent`](../interfaces/WatchOnChangeEvent.md)\> + +#### Defined in + +[client/AbstractPowerSyncDatabase.ts:456](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/AbstractPowerSyncDatabase.ts#L456) + +___ + +### readLock + +▸ **readLock**<`T`\>(`callback`): `Promise`<`T`\> + +Takes a read lock, without starting a transaction. + +In most cases, [readTransaction] should be used instead. + +#### Type parameters + +| Name | +| :------ | +| `T` | + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `callback` | (`db`: [`DBAdapter`](../interfaces/DBAdapter.md)) => `Promise`<`T`\> | + +#### Returns + +`Promise`<`T`\> + +#### Defined in + +[client/AbstractPowerSyncDatabase.ts:374](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/AbstractPowerSyncDatabase.ts#L374) + +___ + +### readTransaction + +▸ **readTransaction**<`T`\>(`callback`, `lockTimeout?`): `Promise`<`T`\> + +#### Type parameters + +| Name | +| :------ | +| `T` | + +#### Parameters + +| Name | Type | Default value | +| :------ | :------ | :------ | +| `callback` | (`tx`: [`Transaction`](../interfaces/Transaction.md)) => `Promise`<`T`\> | `undefined` | +| `lockTimeout` | `number` | `DEFAULT_LOCK_TIMEOUT_MS` | + +#### Returns + +`Promise`<`T`\> + +#### Defined in + +[client/AbstractPowerSyncDatabase.ts:392](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/AbstractPowerSyncDatabase.ts#L392) + +___ + +### registerListener + +▸ **registerListener**(`listener`): () => `void` + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `listener` | `Partial`<[`PowerSyncDBListener`](../interfaces/PowerSyncDBListener.md)\> | + +#### Returns + +`fn` + +▸ (): `void` + +##### Returns + +`void` + +#### Inherited from + +[BaseObserver](BaseObserver.md).[registerListener](BaseObserver.md#registerlistener) + +#### Defined in + +[utils/BaseObserver.ts:18](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/utils/BaseObserver.ts#L18) + +___ + +### waitForReady + +▸ **waitForReady**(): `Promise`<`void`\> + +#### Returns + +`Promise`<`void`\> + +A promise which will resolve once initialization is completed. + +#### Defined in + +[client/AbstractPowerSyncDatabase.ts:110](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/AbstractPowerSyncDatabase.ts#L110) + +___ + +### watch + +▸ **watch**(`sql`, `parameters?`, `options?`): `AsyncIterable`<[`QueryResult`](../interfaces/QueryResult.md)\> + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `sql` | `string` | +| `parameters?` | `any`[] | +| `options?` | [`SQLWatchOptions`](../interfaces/SQLWatchOptions.md) | + +#### Returns + +`AsyncIterable`<[`QueryResult`](../interfaces/QueryResult.md)\> + +#### Defined in + +[client/AbstractPowerSyncDatabase.ts:423](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/AbstractPowerSyncDatabase.ts#L423) + +___ + +### writeLock + +▸ **writeLock**<`T`\>(`callback`): `Promise`<`T`\> + +Takes a global lock, without starting a transaction. +In most cases, [writeTransaction] should be used instead. + +#### Type parameters + +| Name | +| :------ | +| `T` | + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `callback` | (`db`: [`DBAdapter`](../interfaces/DBAdapter.md)) => `Promise`<`T`\> | + +#### Returns + +`Promise`<`T`\> + +#### Defined in + +[client/AbstractPowerSyncDatabase.ts:383](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/AbstractPowerSyncDatabase.ts#L383) + +___ + +### writeTransaction + +▸ **writeTransaction**<`T`\>(`callback`, `lockTimeout?`): `Promise`<`T`\> + +#### Type parameters + +| Name | +| :------ | +| `T` | + +#### Parameters + +| Name | Type | Default value | +| :------ | :------ | :------ | +| `callback` | (`tx`: [`Transaction`](../interfaces/Transaction.md)) => `Promise`<`T`\> | `undefined` | +| `lockTimeout` | `number` | `DEFAULT_LOCK_TIMEOUT_MS` | + +#### Returns + +`Promise`<`T`\> + +#### Defined in + +[client/AbstractPowerSyncDatabase.ts:407](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/AbstractPowerSyncDatabase.ts#L407) diff --git a/docs/docs/common-sdk/classes/AbstractPowerSyncDatabaseOpenFactory.md b/docs/docs/common-sdk/classes/AbstractPowerSyncDatabaseOpenFactory.md new file mode 100644 index 00000000..ac4778fa --- /dev/null +++ b/docs/docs/common-sdk/classes/AbstractPowerSyncDatabaseOpenFactory.md @@ -0,0 +1,113 @@ +--- +id: "AbstractPowerSyncDatabaseOpenFactory" +title: "Class: AbstractPowerSyncDatabaseOpenFactory" +sidebar_label: "AbstractPowerSyncDatabaseOpenFactory" +sidebar_position: 0 +custom_edit_url: null +--- + +## Constructors + +### constructor + +• **new AbstractPowerSyncDatabaseOpenFactory**(`options`): [`AbstractPowerSyncDatabaseOpenFactory`](AbstractPowerSyncDatabaseOpenFactory.md) + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `options` | [`PowerSyncOpenFactoryOptions`](../interfaces/PowerSyncOpenFactoryOptions.md) | + +#### Returns + +[`AbstractPowerSyncDatabaseOpenFactory`](AbstractPowerSyncDatabaseOpenFactory.md) + +#### Defined in + +[client/AbstractPowerSyncOpenFactory.ts:18](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/AbstractPowerSyncOpenFactory.ts#L18) + +## Properties + +### options + +• `Protected` **options**: [`PowerSyncOpenFactoryOptions`](../interfaces/PowerSyncOpenFactoryOptions.md) + +#### Defined in + +[client/AbstractPowerSyncOpenFactory.ts:18](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/AbstractPowerSyncOpenFactory.ts#L18) + +## Accessors + +### schema + +• `get` **schema**(): [`Schema`](Schema.md) + +#### Returns + +[`Schema`](Schema.md) + +#### Defined in + +[client/AbstractPowerSyncOpenFactory.ts:20](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/AbstractPowerSyncOpenFactory.ts#L20) + +## Methods + +### generateInstance + +▸ **generateInstance**(`options`): [`AbstractPowerSyncDatabase`](AbstractPowerSyncDatabase.md) + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `options` | [`PowerSyncDatabaseOptions`](../interfaces/PowerSyncDatabaseOptions.md) | + +#### Returns + +[`AbstractPowerSyncDatabase`](AbstractPowerSyncDatabase.md) + +#### Defined in + +[client/AbstractPowerSyncOpenFactory.ts:33](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/AbstractPowerSyncOpenFactory.ts#L33) + +___ + +### generateOptions + +▸ **generateOptions**(): [`PowerSyncDatabaseOptions`](../interfaces/PowerSyncDatabaseOptions.md) + +#### Returns + +[`PowerSyncDatabaseOptions`](../interfaces/PowerSyncDatabaseOptions.md) + +#### Defined in + +[client/AbstractPowerSyncOpenFactory.ts:26](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/AbstractPowerSyncOpenFactory.ts#L26) + +___ + +### getInstance + +▸ **getInstance**(): [`AbstractPowerSyncDatabase`](AbstractPowerSyncDatabase.md) + +#### Returns + +[`AbstractPowerSyncDatabase`](AbstractPowerSyncDatabase.md) + +#### Defined in + +[client/AbstractPowerSyncOpenFactory.ts:35](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/AbstractPowerSyncOpenFactory.ts#L35) + +___ + +### openDB + +▸ **openDB**(): [`DBAdapter`](../interfaces/DBAdapter.md) + +#### Returns + +[`DBAdapter`](../interfaces/DBAdapter.md) + +#### Defined in + +[client/AbstractPowerSyncOpenFactory.ts:24](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/AbstractPowerSyncOpenFactory.ts#L24) diff --git a/docs/docs/common-sdk/classes/AbstractRemote.md b/docs/docs/common-sdk/classes/AbstractRemote.md new file mode 100644 index 00000000..a3404a2b --- /dev/null +++ b/docs/docs/common-sdk/classes/AbstractRemote.md @@ -0,0 +1,180 @@ +--- +id: "AbstractRemote" +title: "Class: AbstractRemote" +sidebar_label: "AbstractRemote" +sidebar_position: 0 +custom_edit_url: null +--- + +## Constructors + +### constructor + +• **new AbstractRemote**(`connector`, `logger?`): [`AbstractRemote`](AbstractRemote.md) + +#### Parameters + +| Name | Type | Default value | +| :------ | :------ | :------ | +| `connector` | [`RemoteConnector`](../modules.md#remoteconnector) | `undefined` | +| `logger` | `ILogger` | `DEFAULT_REMOTE_LOGGER` | + +#### Returns + +[`AbstractRemote`](AbstractRemote.md) + +#### Defined in + +[client/sync/stream/AbstractRemote.ts:16](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/stream/AbstractRemote.ts#L16) + +## Properties + +### connector + +• `Protected` **connector**: [`RemoteConnector`](../modules.md#remoteconnector) + +#### Defined in + +[client/sync/stream/AbstractRemote.ts:16](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/stream/AbstractRemote.ts#L16) + +___ + +### credentials + +• `Protected` `Optional` **credentials**: [`PowerSyncCredentials`](../interfaces/PowerSyncCredentials.md) + +#### Defined in + +[client/sync/stream/AbstractRemote.ts:14](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/stream/AbstractRemote.ts#L14) + +___ + +### logger + +• `Protected` **logger**: `ILogger` = `DEFAULT_REMOTE_LOGGER` + +#### Defined in + +[client/sync/stream/AbstractRemote.ts:16](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/stream/AbstractRemote.ts#L16) + +## Methods + +### get + +▸ **get**(`path`, `headers?`): `Promise`<`any`\> + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `path` | `string` | +| `headers?` | `Record`<`string`, `string`\> | + +#### Returns + +`Promise`<`any`\> + +#### Defined in + +[client/sync/stream/AbstractRemote.ts:47](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/stream/AbstractRemote.ts#L47) + +___ + +### getCredentials + +▸ **getCredentials**(): `Promise`<[`PowerSyncCredentials`](../interfaces/PowerSyncCredentials.md)\> + +#### Returns + +`Promise`<[`PowerSyncCredentials`](../interfaces/PowerSyncCredentials.md)\> + +#### Defined in + +[client/sync/stream/AbstractRemote.ts:18](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/stream/AbstractRemote.ts#L18) + +___ + +### getHeaders + +▸ **getHeaders**(): `Promise`<\{ `Authorization`: `string` ; `content-type`: `string` = 'application/json' }\> + +#### Returns + +`Promise`<\{ `Authorization`: `string` ; `content-type`: `string` = 'application/json' }\> + +#### Defined in + +[client/sync/stream/AbstractRemote.ts:38](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/stream/AbstractRemote.ts#L38) + +___ + +### getToken + +▸ **getToken**(): `Promise`<`string`\> + +#### Returns + +`Promise`<`string`\> + +#### Defined in + +[client/sync/stream/AbstractRemote.ts:27](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/stream/AbstractRemote.ts#L27) + +___ + +### isAvailable + +▸ **isAvailable**(): `boolean` + +#### Returns + +`boolean` + +#### Defined in + +[client/sync/stream/AbstractRemote.ts:50](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/stream/AbstractRemote.ts#L50) + +___ + +### post + +▸ **post**(`path`, `data`, `headers?`): `Promise`<`any`\> + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `path` | `string` | +| `data` | `any` | +| `headers?` | `Record`<`string`, `string`\> | + +#### Returns + +`Promise`<`any`\> + +#### Defined in + +[client/sync/stream/AbstractRemote.ts:46](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/stream/AbstractRemote.ts#L46) + +___ + +### postStreaming + +▸ **postStreaming**(`path`, `data`, `headers?`, `signal?`): `Promise`<`any`\> + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `path` | `string` | +| `data` | `any` | +| `headers?` | `Record`<`string`, `string`\> | +| `signal?` | `AbortSignal` | + +#### Returns + +`Promise`<`any`\> + +#### Defined in + +[client/sync/stream/AbstractRemote.ts:48](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/stream/AbstractRemote.ts#L48) diff --git a/docs/docs/common-sdk/classes/AbstractStreamingSyncImplementation.md b/docs/docs/common-sdk/classes/AbstractStreamingSyncImplementation.md new file mode 100644 index 00000000..afb4dd0a --- /dev/null +++ b/docs/docs/common-sdk/classes/AbstractStreamingSyncImplementation.md @@ -0,0 +1,384 @@ +--- +id: "AbstractStreamingSyncImplementation" +title: "Class: AbstractStreamingSyncImplementation" +sidebar_label: "AbstractStreamingSyncImplementation" +sidebar_position: 0 +custom_edit_url: null +--- + +## Hierarchy + +- [`BaseObserver`](BaseObserver.md)<[`StreamingSyncImplementationListener`](../interfaces/StreamingSyncImplementationListener.md)\> + + ↳ **`AbstractStreamingSyncImplementation`** + +## Constructors + +### constructor + +• **new AbstractStreamingSyncImplementation**(`options`): [`AbstractStreamingSyncImplementation`](AbstractStreamingSyncImplementation.md) + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `options` | [`AbstractStreamingSyncImplementationOptions`](../interfaces/AbstractStreamingSyncImplementationOptions.md) | + +#### Returns + +[`AbstractStreamingSyncImplementation`](AbstractStreamingSyncImplementation.md) + +#### Overrides + +[BaseObserver](BaseObserver.md).[constructor](BaseObserver.md#constructor) + +#### Defined in + +[client/sync/stream/AbstractStreamingSyncImplementation.ts:59](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/stream/AbstractStreamingSyncImplementation.ts#L59) + +## Properties + +### \_isConnected + +• `Protected` **\_isConnected**: `boolean` + +#### Defined in + +[client/sync/stream/AbstractStreamingSyncImplementation.ts:57](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/stream/AbstractStreamingSyncImplementation.ts#L57) + +___ + +### \_lastSyncedAt + +• `Protected` **\_lastSyncedAt**: `Date` + +#### Defined in + +[client/sync/stream/AbstractStreamingSyncImplementation.ts:52](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/stream/AbstractStreamingSyncImplementation.ts#L52) + +___ + +### isUploadingCrud + +• `Private` **isUploadingCrud**: `boolean` + +#### Defined in + +[client/sync/stream/AbstractStreamingSyncImplementation.ts:55](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/stream/AbstractStreamingSyncImplementation.ts#L55) + +___ + +### listeners + +• `Protected` **listeners**: `Object` + +#### Index signature + +▪ [id: `string`]: `Partial`<`T`\> + +#### Inherited from + +[BaseObserver](BaseObserver.md).[listeners](BaseObserver.md#listeners) + +#### Defined in + +[utils/BaseObserver.ts:12](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/utils/BaseObserver.ts#L12) + +___ + +### options + +• `Protected` **options**: [`AbstractStreamingSyncImplementationOptions`](../interfaces/AbstractStreamingSyncImplementationOptions.md) + +#### Defined in + +[client/sync/stream/AbstractStreamingSyncImplementation.ts:53](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/stream/AbstractStreamingSyncImplementation.ts#L53) + +## Accessors + +### isConnected + +• `get` **isConnected**(): `boolean` + +#### Returns + +`boolean` + +#### Defined in + +[client/sync/stream/AbstractStreamingSyncImplementation.ts:74](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/stream/AbstractStreamingSyncImplementation.ts#L74) + +___ + +### lastSyncedAt + +• `get` **lastSyncedAt**(): `Date` + +#### Returns + +`Date` + +#### Defined in + +[client/sync/stream/AbstractStreamingSyncImplementation.ts:66](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/stream/AbstractStreamingSyncImplementation.ts#L66) + +___ + +### logger + +• `get` **logger**(): `ILogger` + +#### Returns + +`ILogger` + +#### Defined in + +[client/sync/stream/AbstractStreamingSyncImplementation.ts:70](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/stream/AbstractStreamingSyncImplementation.ts#L70) + +## Methods + +### \_uploadAllCrud + +▸ **_uploadAllCrud**(): `Promise`<`void`\> + +#### Returns + +`Promise`<`void`\> + +#### Defined in + +[client/sync/stream/AbstractStreamingSyncImplementation.ts:91](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/stream/AbstractStreamingSyncImplementation.ts#L91) + +___ + +### delayRetry + +▸ **delayRetry**(): `Promise`<`unknown`\> + +#### Returns + +`Promise`<`unknown`\> + +#### Defined in + +[client/sync/stream/AbstractStreamingSyncImplementation.ts:314](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/stream/AbstractStreamingSyncImplementation.ts#L314) + +___ + +### getWriteCheckpoint + +▸ **getWriteCheckpoint**(): `Promise`<`string`\> + +#### Returns + +`Promise`<`string`\> + +#### Defined in + +[client/sync/stream/AbstractStreamingSyncImplementation.ts:120](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/stream/AbstractStreamingSyncImplementation.ts#L120) + +___ + +### hasCompletedSync + +▸ **hasCompletedSync**(): `Promise`<`boolean`\> + +#### Returns + +`Promise`<`boolean`\> + +#### Defined in + +[client/sync/stream/AbstractStreamingSyncImplementation.ts:80](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/stream/AbstractStreamingSyncImplementation.ts#L80) + +___ + +### iterateListeners + +▸ **iterateListeners**(`cb`): `void` + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `cb` | (`listener`: `Partial`<[`StreamingSyncImplementationListener`](../interfaces/StreamingSyncImplementationListener.md)\>) => `any` | + +#### Returns + +`void` + +#### Inherited from + +[BaseObserver](BaseObserver.md).[iterateListeners](BaseObserver.md#iteratelisteners) + +#### Defined in + +[utils/BaseObserver.ts:26](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/utils/BaseObserver.ts#L26) + +___ + +### obtainLock + +▸ **obtainLock**<`T`\>(`lockOptions`): `Promise`<`T`\> + +#### Type parameters + +| Name | +| :------ | +| `T` | + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `lockOptions` | [`LockOptions`](../interfaces/LockOptions.md)<`T`\> | + +#### Returns + +`Promise`<`T`\> + +#### Defined in + +[client/sync/stream/AbstractStreamingSyncImplementation.ts:78](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/stream/AbstractStreamingSyncImplementation.ts#L78) + +___ + +### registerListener + +▸ **registerListener**(`listener`): () => `void` + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `listener` | `Partial`<[`StreamingSyncImplementationListener`](../interfaces/StreamingSyncImplementationListener.md)\> | + +#### Returns + +`fn` + +▸ (): `void` + +##### Returns + +`void` + +#### Inherited from + +[BaseObserver](BaseObserver.md).[registerListener](BaseObserver.md#registerlistener) + +#### Defined in + +[utils/BaseObserver.ts:18](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/utils/BaseObserver.ts#L18) + +___ + +### streamingSync + +▸ **streamingSync**(`signal?`): `Promise`<`void`\> + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `signal?` | `AbortSignal` | + +#### Returns + +`Promise`<`void`\> + +#### Defined in + +[client/sync/stream/AbstractStreamingSyncImplementation.ts:125](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/stream/AbstractStreamingSyncImplementation.ts#L125) + +___ + +### streamingSyncIteration + +▸ **streamingSyncIteration**(`signal?`, `progress?`): `Promise`<\{ `retry?`: `boolean` }\> + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `signal?` | `AbortSignal` | +| `progress?` | () => `void` | + +#### Returns + +`Promise`<\{ `retry?`: `boolean` }\> + +#### Defined in + +[client/sync/stream/AbstractStreamingSyncImplementation.ts:142](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/stream/AbstractStreamingSyncImplementation.ts#L142) + +___ + +### streamingSyncRequest + +▸ **streamingSyncRequest**(`req`, `signal`): `AsyncGenerator`<[`StreamingSyncLine`](../modules.md#streamingsyncline), `any`, `unknown`\> + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `req` | [`StreamingSyncRequest`](../interfaces/StreamingSyncRequest.md) | +| `signal` | `AbortSignal` | + +#### Returns + +`AsyncGenerator`<[`StreamingSyncLine`](../modules.md#streamingsyncline), `any`, `unknown`\> + +#### Defined in + +[client/sync/stream/AbstractStreamingSyncImplementation.ts:284](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/stream/AbstractStreamingSyncImplementation.ts#L284) + +___ + +### triggerCrudUpload + +▸ **triggerCrudUpload**(): `void` + +#### Returns + +`void` + +#### Defined in + +[client/sync/stream/AbstractStreamingSyncImplementation.ts:84](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/stream/AbstractStreamingSyncImplementation.ts#L84) + +___ + +### updateSyncStatus + +▸ **updateSyncStatus**(`connected`, `lastSyncedAt?`): `void` + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `connected` | `boolean` | +| `lastSyncedAt?` | `Date` | + +#### Returns + +`void` + +#### Defined in + +[client/sync/stream/AbstractStreamingSyncImplementation.ts:303](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/stream/AbstractStreamingSyncImplementation.ts#L303) + +___ + +### uploadCrudBatch + +▸ **uploadCrudBatch**(): `Promise`<`boolean`\> + +#### Returns + +`Promise`<`boolean`\> + +#### Defined in + +[client/sync/stream/AbstractStreamingSyncImplementation.ts:109](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/stream/AbstractStreamingSyncImplementation.ts#L109) diff --git a/docs/docs/common-sdk/classes/BaseObserver.md b/docs/docs/common-sdk/classes/BaseObserver.md new file mode 100644 index 00000000..112e645d --- /dev/null +++ b/docs/docs/common-sdk/classes/BaseObserver.md @@ -0,0 +1,109 @@ +--- +id: "BaseObserver" +title: "Class: BaseObserver" +sidebar_label: "BaseObserver" +sidebar_position: 0 +custom_edit_url: null +--- + +## Type parameters + +| Name | Type | +| :------ | :------ | +| `T` | extends [`BaseListener`](../modules.md#baselistener) = [`BaseListener`](../modules.md#baselistener) | + +## Hierarchy + +- **`BaseObserver`** + + ↳ [`AbstractPowerSyncDatabase`](AbstractPowerSyncDatabase.md) + + ↳ [`AbstractStreamingSyncImplementation`](AbstractStreamingSyncImplementation.md) + +## Implements + +- [`BaseObserverInterface`](../interfaces/BaseObserverInterface.md)<`T`\> + +## Constructors + +### constructor + +• **new BaseObserver**<`T`\>(): [`BaseObserver`](BaseObserver.md)<`T`\> + +#### Type parameters + +| Name | Type | +| :------ | :------ | +| `T` | extends [`BaseListener`](../modules.md#baselistener) = [`BaseListener`](../modules.md#baselistener) | + +#### Returns + +[`BaseObserver`](BaseObserver.md)<`T`\> + +#### Defined in + +[utils/BaseObserver.ts:14](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/utils/BaseObserver.ts#L14) + +## Properties + +### listeners + +• `Protected` **listeners**: `Object` + +#### Index signature + +▪ [id: `string`]: `Partial`<`T`\> + +#### Defined in + +[utils/BaseObserver.ts:12](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/utils/BaseObserver.ts#L12) + +## Methods + +### iterateListeners + +▸ **iterateListeners**(`cb`): `void` + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `cb` | (`listener`: `Partial`<`T`\>) => `any` | + +#### Returns + +`void` + +#### Defined in + +[utils/BaseObserver.ts:26](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/utils/BaseObserver.ts#L26) + +___ + +### registerListener + +▸ **registerListener**(`listener`): () => `void` + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `listener` | `Partial`<`T`\> | + +#### Returns + +`fn` + +▸ (): `void` + +##### Returns + +`void` + +#### Implementation of + +[BaseObserverInterface](../interfaces/BaseObserverInterface.md).[registerListener](../interfaces/BaseObserverInterface.md#registerlistener) + +#### Defined in + +[utils/BaseObserver.ts:18](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/utils/BaseObserver.ts#L18) diff --git a/docs/docs/common-sdk/classes/Column.md b/docs/docs/common-sdk/classes/Column.md new file mode 100644 index 00000000..aba6a7b5 --- /dev/null +++ b/docs/docs/common-sdk/classes/Column.md @@ -0,0 +1,84 @@ +--- +id: "Column" +title: "Class: Column" +sidebar_label: "Column" +sidebar_position: 0 +custom_edit_url: null +--- + +## Constructors + +### constructor + +• **new Column**(`options`): [`Column`](Column.md) + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `options` | [`ColumnOptions`](../interfaces/ColumnOptions.md) | + +#### Returns + +[`Column`](Column.md) + +#### Defined in + +[db/Column.ts:14](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/db/Column.ts#L14) + +## Properties + +### options + +• `Protected` **options**: [`ColumnOptions`](../interfaces/ColumnOptions.md) + +#### Defined in + +[db/Column.ts:14](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/db/Column.ts#L14) + +## Accessors + +### name + +• `get` **name**(): `string` + +#### Returns + +`string` + +#### Defined in + +[db/Column.ts:16](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/db/Column.ts#L16) + +___ + +### type + +• `get` **type**(): [`ColumnType`](../enums/ColumnType.md) + +#### Returns + +[`ColumnType`](../enums/ColumnType.md) + +#### Defined in + +[db/Column.ts:20](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/db/Column.ts#L20) + +## Methods + +### toJSON + +▸ **toJSON**(): `Object` + +#### Returns + +`Object` + +| Name | Type | +| :------ | :------ | +| `name` | `string` | +| `type` | [`ColumnType`](../enums/ColumnType.md) | + +#### Defined in + +[db/Column.ts:24](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/db/Column.ts#L24) diff --git a/docs/docs/common-sdk/classes/CrudBatch.md b/docs/docs/common-sdk/classes/CrudBatch.md new file mode 100644 index 00000000..fc2a7b37 --- /dev/null +++ b/docs/docs/common-sdk/classes/CrudBatch.md @@ -0,0 +1,79 @@ +--- +id: "CrudBatch" +title: "Class: CrudBatch" +sidebar_label: "CrudBatch" +sidebar_position: 0 +custom_edit_url: null +--- + +## Hierarchy + +- **`CrudBatch`** + + ↳ [`CrudTransaction`](CrudTransaction.md) + +## Constructors + +### constructor + +• **new CrudBatch**(`crud`, `haveMore`, `complete`): [`CrudBatch`](CrudBatch.md) + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `crud` | [`CrudEntry`](CrudEntry.md)[] | +| `haveMore` | `boolean` | +| `complete` | (`writeCheckpoint?`: `string`) => `Promise`<`void`\> | + +#### Returns + +[`CrudBatch`](CrudBatch.md) + +#### Defined in + +[client/sync/bucket/CrudBatch.ts:4](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/CrudBatch.ts#L4) + +## Properties + +### complete + +• **complete**: (`writeCheckpoint?`: `string`) => `Promise`<`void`\> + +#### Type declaration + +▸ (`writeCheckpoint?`): `Promise`<`void`\> + +##### Parameters + +| Name | Type | +| :------ | :------ | +| `writeCheckpoint?` | `string` | + +##### Returns + +`Promise`<`void`\> + +#### Defined in + +[client/sync/bucket/CrudBatch.ts:7](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/CrudBatch.ts#L7) + +___ + +### crud + +• **crud**: [`CrudEntry`](CrudEntry.md)[] + +#### Defined in + +[client/sync/bucket/CrudBatch.ts:5](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/CrudBatch.ts#L5) + +___ + +### haveMore + +• **haveMore**: `boolean` + +#### Defined in + +[client/sync/bucket/CrudBatch.ts:6](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/CrudBatch.ts#L6) diff --git a/docs/docs/common-sdk/classes/CrudEntry.md b/docs/docs/common-sdk/classes/CrudEntry.md new file mode 100644 index 00000000..0c658064 --- /dev/null +++ b/docs/docs/common-sdk/classes/CrudEntry.md @@ -0,0 +1,140 @@ +--- +id: "CrudEntry" +title: "Class: CrudEntry" +sidebar_label: "CrudEntry" +sidebar_position: 0 +custom_edit_url: null +--- + +## Constructors + +### constructor + +• **new CrudEntry**(`clientId`, `op`, `table`, `id`, `transactionId?`, `opData?`): [`CrudEntry`](CrudEntry.md) + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `clientId` | `number` | +| `op` | [`UpdateType`](../enums/UpdateType.md) | +| `table` | `string` | +| `id` | `string` | +| `transactionId?` | `number` | +| `opData?` | `Record`<`string`, `any`\> | + +#### Returns + +[`CrudEntry`](CrudEntry.md) + +#### Defined in + +[client/sync/bucket/CrudEntry.ts:54](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/CrudEntry.ts#L54) + +## Properties + +### clientId + +• **clientId**: `number` + +#### Defined in + +[client/sync/bucket/CrudEntry.ts:42](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/CrudEntry.ts#L42) + +___ + +### id + +• **id**: `string` + +#### Defined in + +[client/sync/bucket/CrudEntry.ts:43](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/CrudEntry.ts#L43) + +___ + +### op + +• **op**: [`UpdateType`](../enums/UpdateType.md) + +#### Defined in + +[client/sync/bucket/CrudEntry.ts:44](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/CrudEntry.ts#L44) + +___ + +### opData + +• `Optional` **opData**: `Record`<`string`, `any`\> + +#### Defined in + +[client/sync/bucket/CrudEntry.ts:45](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/CrudEntry.ts#L45) + +___ + +### table + +• **table**: `string` + +#### Defined in + +[client/sync/bucket/CrudEntry.ts:46](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/CrudEntry.ts#L46) + +___ + +### transactionId + +• `Optional` **transactionId**: `number` + +#### Defined in + +[client/sync/bucket/CrudEntry.ts:47](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/CrudEntry.ts#L47) + +## Methods + +### hashCode + +▸ **hashCode**(): `string` + +#### Returns + +`string` + +#### Defined in + +[client/sync/bucket/CrudEntry.ts:81](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/CrudEntry.ts#L81) + +___ + +### toJSON + +▸ **toJSON**(): [`CrudEntryOutputJSON`](../modules.md#crudentryoutputjson) + +#### Returns + +[`CrudEntryOutputJSON`](../modules.md#crudentryoutputjson) + +#### Defined in + +[client/sync/bucket/CrudEntry.ts:70](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/CrudEntry.ts#L70) + +___ + +### fromRow + +▸ **fromRow**(`dbRow`): [`CrudEntry`](CrudEntry.md) + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `dbRow` | [`CrudEntryJSON`](../modules.md#crudentryjson) | + +#### Returns + +[`CrudEntry`](CrudEntry.md) + +#### Defined in + +[client/sync/bucket/CrudEntry.ts:49](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/CrudEntry.ts#L49) diff --git a/docs/docs/common-sdk/classes/CrudTransaction.md b/docs/docs/common-sdk/classes/CrudTransaction.md new file mode 100644 index 00000000..329d4626 --- /dev/null +++ b/docs/docs/common-sdk/classes/CrudTransaction.md @@ -0,0 +1,105 @@ +--- +id: "CrudTransaction" +title: "Class: CrudTransaction" +sidebar_label: "CrudTransaction" +sidebar_position: 0 +custom_edit_url: null +--- + +## Hierarchy + +- [`CrudBatch`](CrudBatch.md) + + ↳ **`CrudTransaction`** + +## Constructors + +### constructor + +• **new CrudTransaction**(`crud`, `complete`, `transactionId?`): [`CrudTransaction`](CrudTransaction.md) + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `crud` | [`CrudEntry`](CrudEntry.md)[] | +| `complete` | (`checkpoint?`: `string`) => `Promise`<`void`\> | +| `transactionId?` | `number` | + +#### Returns + +[`CrudTransaction`](CrudTransaction.md) + +#### Overrides + +[CrudBatch](CrudBatch.md).[constructor](CrudBatch.md#constructor) + +#### Defined in + +[client/sync/bucket/CrudTransaction.ts:5](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/CrudTransaction.ts#L5) + +## Properties + +### complete + +• **complete**: (`checkpoint?`: `string`) => `Promise`<`void`\> + +#### Type declaration + +▸ (`checkpoint?`): `Promise`<`void`\> + +##### Parameters + +| Name | Type | +| :------ | :------ | +| `checkpoint?` | `string` | + +##### Returns + +`Promise`<`void`\> + +#### Inherited from + +[CrudBatch](CrudBatch.md).[complete](CrudBatch.md#complete) + +#### Defined in + +[client/sync/bucket/CrudTransaction.ts:7](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/CrudTransaction.ts#L7) + +___ + +### crud + +• **crud**: [`CrudEntry`](CrudEntry.md)[] + +#### Inherited from + +[CrudBatch](CrudBatch.md).[crud](CrudBatch.md#crud) + +#### Defined in + +[client/sync/bucket/CrudTransaction.ts:6](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/CrudTransaction.ts#L6) + +___ + +### haveMore + +• **haveMore**: `boolean` + +#### Inherited from + +[CrudBatch](CrudBatch.md).[haveMore](CrudBatch.md#havemore) + +#### Defined in + +[client/sync/bucket/CrudBatch.ts:6](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/CrudBatch.ts#L6) + +___ + +### transactionId + +• `Optional` **transactionId**: `number` + +#### Defined in + +[client/sync/bucket/CrudTransaction.ts:8](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/CrudTransaction.ts#L8) diff --git a/docs/docs/common-sdk/classes/Index.md b/docs/docs/common-sdk/classes/Index.md new file mode 100644 index 00000000..f65178de --- /dev/null +++ b/docs/docs/common-sdk/classes/Index.md @@ -0,0 +1,111 @@ +--- +id: "Index" +title: "Class: Index" +sidebar_label: "Index" +sidebar_position: 0 +custom_edit_url: null +--- + +## Constructors + +### constructor + +• **new Index**(`options`): [`Index`](Index.md) + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `options` | [`IndexOptions`](../interfaces/IndexOptions.md) | + +#### Returns + +[`Index`](Index.md) + +#### Defined in + +[db/schema/Index.ts:21](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/db/schema/Index.ts#L21) + +## Properties + +### options + +• `Protected` **options**: [`IndexOptions`](../interfaces/IndexOptions.md) + +#### Defined in + +[db/schema/Index.ts:21](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/db/schema/Index.ts#L21) + +## Accessors + +### columns + +• `get` **columns**(): [`IndexedColumn`](IndexedColumn.md)[] + +#### Returns + +[`IndexedColumn`](IndexedColumn.md)[] + +#### Defined in + +[db/schema/Index.ts:29](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/db/schema/Index.ts#L29) + +___ + +### name + +• `get` **name**(): `string` + +#### Returns + +`string` + +#### Defined in + +[db/schema/Index.ts:25](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/db/schema/Index.ts#L25) + +## Methods + +### toJSON + +▸ **toJSON**(`table`): `Object` + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `table` | [`Table`](Table.md) | + +#### Returns + +`Object` + +| Name | Type | +| :------ | :------ | +| `columns` | \{ `ascending`: `boolean` ; `name`: `string` ; `type`: [`ColumnType`](../enums/ColumnType.md) }[] | +| `name` | `string` | + +#### Defined in + +[db/schema/Index.ts:33](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/db/schema/Index.ts#L33) + +___ + +### createAscending + +▸ **createAscending**(`options`, `columnNames`): [`Index`](Index.md) + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `options` | [`IndexOptions`](../interfaces/IndexOptions.md) | +| `columnNames` | `string`[] | + +#### Returns + +[`Index`](Index.md) + +#### Defined in + +[db/schema/Index.ts:14](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/db/schema/Index.ts#L14) diff --git a/docs/docs/common-sdk/classes/IndexedColumn.md b/docs/docs/common-sdk/classes/IndexedColumn.md new file mode 100644 index 00000000..fdc07273 --- /dev/null +++ b/docs/docs/common-sdk/classes/IndexedColumn.md @@ -0,0 +1,111 @@ +--- +id: "IndexedColumn" +title: "Class: IndexedColumn" +sidebar_label: "IndexedColumn" +sidebar_position: 0 +custom_edit_url: null +--- + +## Constructors + +### constructor + +• **new IndexedColumn**(`options`): [`IndexedColumn`](IndexedColumn.md) + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `options` | [`IndexColumnOptions`](../interfaces/IndexColumnOptions.md) | + +#### Returns + +[`IndexedColumn`](IndexedColumn.md) + +#### Defined in + +[db/schema/IndexedColumn.ts:23](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/db/schema/IndexedColumn.ts#L23) + +## Properties + +### options + +• `Protected` **options**: [`IndexColumnOptions`](../interfaces/IndexColumnOptions.md) + +#### Defined in + +[db/schema/IndexedColumn.ts:14](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/db/schema/IndexedColumn.ts#L14) + +## Accessors + +### ascending + +• `get` **ascending**(): `boolean` + +#### Returns + +`boolean` + +#### Defined in + +[db/schema/IndexedColumn.ts:31](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/db/schema/IndexedColumn.ts#L31) + +___ + +### name + +• `get` **name**(): `string` + +#### Returns + +`string` + +#### Defined in + +[db/schema/IndexedColumn.ts:27](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/db/schema/IndexedColumn.ts#L27) + +## Methods + +### toJSON + +▸ **toJSON**(`table`): `Object` + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `table` | [`Table`](Table.md) | + +#### Returns + +`Object` + +| Name | Type | +| :------ | :------ | +| `ascending` | `boolean` | +| `name` | `string` | +| `type` | [`ColumnType`](../enums/ColumnType.md) | + +#### Defined in + +[db/schema/IndexedColumn.ts:35](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/db/schema/IndexedColumn.ts#L35) + +___ + +### createAscending + +▸ **createAscending**(`column`): [`IndexedColumn`](IndexedColumn.md) + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `column` | `string` | + +#### Returns + +[`IndexedColumn`](IndexedColumn.md) + +#### Defined in + +[db/schema/IndexedColumn.ts:16](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/db/schema/IndexedColumn.ts#L16) diff --git a/docs/docs/common-sdk/classes/OpType.md b/docs/docs/common-sdk/classes/OpType.md new file mode 100644 index 00000000..b2ae7ea7 --- /dev/null +++ b/docs/docs/common-sdk/classes/OpType.md @@ -0,0 +1,71 @@ +--- +id: "OpType" +title: "Class: OpType" +sidebar_label: "OpType" +sidebar_position: 0 +custom_edit_url: null +--- + +## Constructors + +### constructor + +• **new OpType**(`value`): [`OpType`](OpType.md) + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `value` | [`OpTypeEnum`](../enums/OpTypeEnum.md) | + +#### Returns + +[`OpType`](OpType.md) + +#### Defined in + +[client/sync/bucket/OpType.ts:15](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/OpType.ts#L15) + +## Properties + +### value + +• **value**: [`OpTypeEnum`](../enums/OpTypeEnum.md) + +#### Defined in + +[client/sync/bucket/OpType.ts:15](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/OpType.ts#L15) + +## Methods + +### toJSON + +▸ **toJSON**(): `string` + +#### Returns + +`string` + +#### Defined in + +[client/sync/bucket/OpType.ts:17](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/OpType.ts#L17) + +___ + +### fromJSON + +▸ **fromJSON**(`jsonValue`): [`OpType`](OpType.md) + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `jsonValue` | `string` | + +#### Returns + +[`OpType`](OpType.md) + +#### Defined in + +[client/sync/bucket/OpType.ts:11](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/OpType.ts#L11) diff --git a/docs/docs/common-sdk/classes/Schema.md b/docs/docs/common-sdk/classes/Schema.md new file mode 100644 index 00000000..93e81da5 --- /dev/null +++ b/docs/docs/common-sdk/classes/Schema.md @@ -0,0 +1,55 @@ +--- +id: "Schema" +title: "Class: Schema" +sidebar_label: "Schema" +sidebar_position: 0 +custom_edit_url: null +--- + +## Constructors + +### constructor + +• **new Schema**(`tables`): [`Schema`](Schema.md) + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `tables` | [`Table`](Table.md)[] | + +#### Returns + +[`Schema`](Schema.md) + +#### Defined in + +[db/schema/Schema.ts:4](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/db/schema/Schema.ts#L4) + +## Properties + +### tables + +• **tables**: [`Table`](Table.md)[] + +#### Defined in + +[db/schema/Schema.ts:4](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/db/schema/Schema.ts#L4) + +## Methods + +### toJSON + +▸ **toJSON**(): `Object` + +#### Returns + +`Object` + +| Name | Type | +| :------ | :------ | +| `tables` | \{ `columns`: \{ `name`: `string` ; `type`: [`ColumnType`](../enums/ColumnType.md) }[] ; `indexes`: \{ `columns`: \{ `ascending`: `boolean` ; `name`: `string` ; `type`: [`ColumnType`](../enums/ColumnType.md) }[] ; `name`: `string` }[] ; `insert_only`: `boolean` ; `local_only`: `boolean` ; `name`: `string` }[] | + +#### Defined in + +[db/schema/Schema.ts:6](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/db/schema/Schema.ts#L6) diff --git a/docs/docs/common-sdk/classes/SqliteBucketStorage.md b/docs/docs/common-sdk/classes/SqliteBucketStorage.md new file mode 100644 index 00000000..00081da4 --- /dev/null +++ b/docs/docs/common-sdk/classes/SqliteBucketStorage.md @@ -0,0 +1,536 @@ +--- +id: "SqliteBucketStorage" +title: "Class: SqliteBucketStorage" +sidebar_label: "SqliteBucketStorage" +sidebar_position: 0 +custom_edit_url: null +--- + +## Implements + +- [`BucketStorageAdapter`](../interfaces/BucketStorageAdapter.md) + +## Constructors + +### constructor + +• **new SqliteBucketStorage**(`db`, `mutex`, `logger?`): [`SqliteBucketStorage`](SqliteBucketStorage.md) + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `db` | [`DBAdapter`](../interfaces/DBAdapter.md) | +| `mutex` | `Mutex` | +| `logger` | `ILogger` | + +#### Returns + +[`SqliteBucketStorage`](SqliteBucketStorage.md) + +#### Defined in + +[client/sync/bucket/SqliteBucketStorage.ts:25](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/SqliteBucketStorage.ts#L25) + +## Properties + +### \_hasCompletedSync + +• `Private` **\_hasCompletedSync**: `boolean` + +#### Defined in + +[client/sync/bucket/SqliteBucketStorage.ts:18](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/SqliteBucketStorage.ts#L18) + +___ + +### compactCounter + +• `Private` **compactCounter**: `number` = `COMPACT_OPERATION_INTERVAL` + +Count up, and do a compact on startup. + +#### Defined in + +[client/sync/bucket/SqliteBucketStorage.ts:23](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/SqliteBucketStorage.ts#L23) + +___ + +### db + +• `Private` **db**: [`DBAdapter`](../interfaces/DBAdapter.md) + +#### Defined in + +[client/sync/bucket/SqliteBucketStorage.ts:26](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/SqliteBucketStorage.ts#L26) + +___ + +### logger + +• `Private` **logger**: `ILogger` + +#### Defined in + +[client/sync/bucket/SqliteBucketStorage.ts:28](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/SqliteBucketStorage.ts#L28) + +___ + +### mutex + +• `Private` **mutex**: `Mutex` + +#### Defined in + +[client/sync/bucket/SqliteBucketStorage.ts:27](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/SqliteBucketStorage.ts#L27) + +___ + +### pendingBucketDeletes + +• `Private` **pendingBucketDeletes**: `boolean` + +#### Defined in + +[client/sync/bucket/SqliteBucketStorage.ts:17](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/SqliteBucketStorage.ts#L17) + +___ + +### tableNames + +• **tableNames**: `Set`<`string`\> + +#### Defined in + +[client/sync/bucket/SqliteBucketStorage.ts:16](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/SqliteBucketStorage.ts#L16) + +___ + +### MAX\_OP\_ID + +▪ `Static` **MAX\_OP\_ID**: `string` = `'9223372036854775807'` + +#### Defined in + +[client/sync/bucket/SqliteBucketStorage.ts:14](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/SqliteBucketStorage.ts#L14) + +## Methods + +### autoCompact + +▸ **autoCompact**(): `Promise`<`void`\> + +Exposed for tests only. + +#### Returns + +`Promise`<`void`\> + +#### Implementation of + +[BucketStorageAdapter](../interfaces/BucketStorageAdapter.md).[autoCompact](../interfaces/BucketStorageAdapter.md#autocompact) + +#### Defined in + +[client/sync/bucket/SqliteBucketStorage.ts:210](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/SqliteBucketStorage.ts#L210) + +___ + +### clearRemoveOps + +▸ **clearRemoveOps**(): `Promise`<`void`\> + +#### Returns + +`Promise`<`void`\> + +#### Defined in + +[client/sync/bucket/SqliteBucketStorage.ts:230](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/SqliteBucketStorage.ts#L230) + +___ + +### deleteBucket + +▸ **deleteBucket**(`bucket`): `Promise`<`void`\> + +Mark a bucket for deletion. + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `bucket` | `string` | + +#### Returns + +`Promise`<`void`\> + +#### Defined in + +[client/sync/bucket/SqliteBucketStorage.ts:86](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/SqliteBucketStorage.ts#L86) + +___ + +### deletePendingBuckets + +▸ **deletePendingBuckets**(): `Promise`<`void`\> + +#### Returns + +`Promise`<`void`\> + +#### Defined in + +[client/sync/bucket/SqliteBucketStorage.ts:215](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/SqliteBucketStorage.ts#L215) + +___ + +### forceCompact + +▸ **forceCompact**(): `Promise`<`void`\> + +Force a compact, for tests. + +#### Returns + +`Promise`<`void`\> + +#### Implementation of + +[BucketStorageAdapter](../interfaces/BucketStorageAdapter.md).[forceCompact](../interfaces/BucketStorageAdapter.md#forcecompact) + +#### Defined in + +[client/sync/bucket/SqliteBucketStorage.ts:203](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/SqliteBucketStorage.ts#L203) + +___ + +### getBucketStates + +▸ **getBucketStates**(): `Promise`<[`BucketState`](../interfaces/BucketState.md)[]\> + +#### Returns + +`Promise`<[`BucketState`](../interfaces/BucketState.md)[]\> + +#### Implementation of + +[BucketStorageAdapter](../interfaces/BucketStorageAdapter.md).[getBucketStates](../interfaces/BucketStorageAdapter.md#getbucketstates) + +#### Defined in + +[client/sync/bucket/SqliteBucketStorage.ts:53](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/SqliteBucketStorage.ts#L53) + +___ + +### getCrudBatch + +▸ **getCrudBatch**(`limit?`): `Promise`<[`CrudBatch`](CrudBatch.md)\> + +Get a batch of objects to send to the server. +When the objects are successfully sent to the server, call .complete() + +#### Parameters + +| Name | Type | Default value | +| :------ | :------ | :------ | +| `limit` | `number` | `100` | + +#### Returns + +`Promise`<[`CrudBatch`](CrudBatch.md)\> + +#### Implementation of + +[BucketStorageAdapter](../interfaces/BucketStorageAdapter.md).[getCrudBatch](../interfaces/BucketStorageAdapter.md#getcrudbatch) + +#### Defined in + +[client/sync/bucket/SqliteBucketStorage.ts:297](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/SqliteBucketStorage.ts#L297) + +___ + +### getMaxOpId + +▸ **getMaxOpId**(): `string` + +#### Returns + +`string` + +#### Implementation of + +[BucketStorageAdapter](../interfaces/BucketStorageAdapter.md).[getMaxOpId](../interfaces/BucketStorageAdapter.md#getmaxopid) + +#### Defined in + +[client/sync/bucket/SqliteBucketStorage.ts:45](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/SqliteBucketStorage.ts#L45) + +___ + +### hasCompletedSync + +▸ **hasCompletedSync**(): `Promise`<`boolean`\> + +#### Returns + +`Promise`<`boolean`\> + +#### Implementation of + +[BucketStorageAdapter](../interfaces/BucketStorageAdapter.md).[hasCompletedSync](../interfaces/BucketStorageAdapter.md#hascompletedsync) + +#### Defined in + +[client/sync/bucket/SqliteBucketStorage.ts:111](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/SqliteBucketStorage.ts#L111) + +___ + +### hasCrud + +▸ **hasCrud**(): `Promise`<`boolean`\> + +#### Returns + +`Promise`<`boolean`\> + +#### Implementation of + +[BucketStorageAdapter](../interfaces/BucketStorageAdapter.md).[hasCrud](../interfaces/BucketStorageAdapter.md#hascrud) + +#### Defined in + +[client/sync/bucket/SqliteBucketStorage.ts:288](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/SqliteBucketStorage.ts#L288) + +___ + +### init + +▸ **init**(): `Promise`<`void`\> + +#### Returns + +`Promise`<`void`\> + +#### Implementation of + +[BucketStorageAdapter](../interfaces/BucketStorageAdapter.md).[init](../interfaces/BucketStorageAdapter.md#init) + +#### Defined in + +[client/sync/bucket/SqliteBucketStorage.ts:35](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/SqliteBucketStorage.ts#L35) + +___ + +### removeBuckets + +▸ **removeBuckets**(`buckets`): `Promise`<`void`\> + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `buckets` | `string`[] | + +#### Returns + +`Promise`<`void`\> + +#### Implementation of + +[BucketStorageAdapter](../interfaces/BucketStorageAdapter.md).[removeBuckets](../interfaces/BucketStorageAdapter.md#removebuckets) + +#### Defined in + +[client/sync/bucket/SqliteBucketStorage.ts:75](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/SqliteBucketStorage.ts#L75) + +___ + +### saveSyncData + +▸ **saveSyncData**(`batch`): `Promise`<`void`\> + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `batch` | [`SyncDataBatch`](SyncDataBatch.md) | + +#### Returns + +`Promise`<`void`\> + +#### Implementation of + +[BucketStorageAdapter](../interfaces/BucketStorageAdapter.md).[saveSyncData](../interfaces/BucketStorageAdapter.md#savesyncdata) + +#### Defined in + +[client/sync/bucket/SqliteBucketStorage.ts:60](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/SqliteBucketStorage.ts#L60) + +___ + +### setTargetCheckpoint + +▸ **setTargetCheckpoint**(`checkpoint`): `Promise`<`void`\> + +Set a target checkpoint. + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `checkpoint` | [`Checkpoint`](../interfaces/Checkpoint.md) | + +#### Returns + +`Promise`<`void`\> + +#### Implementation of + +[BucketStorageAdapter](../interfaces/BucketStorageAdapter.md).[setTargetCheckpoint](../interfaces/BucketStorageAdapter.md#settargetcheckpoint) + +#### Defined in + +[client/sync/bucket/SqliteBucketStorage.ts:340](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/SqliteBucketStorage.ts#L340) + +___ + +### startSession + +▸ **startSession**(): `void` + +Reset any caches. + +#### Returns + +`void` + +#### Implementation of + +[BucketStorageAdapter](../interfaces/BucketStorageAdapter.md).[startSession](../interfaces/BucketStorageAdapter.md#startsession) + +#### Defined in + +[client/sync/bucket/SqliteBucketStorage.ts:51](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/SqliteBucketStorage.ts#L51) + +___ + +### syncLocalDatabase + +▸ **syncLocalDatabase**(`checkpoint`): `Promise`<[`SyncLocalDatabaseResult`](../interfaces/SyncLocalDatabaseResult.md)\> + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `checkpoint` | [`Checkpoint`](../interfaces/Checkpoint.md) | + +#### Returns + +`Promise`<[`SyncLocalDatabaseResult`](../interfaces/SyncLocalDatabaseResult.md)\> + +#### Implementation of + +[BucketStorageAdapter](../interfaces/BucketStorageAdapter.md).[syncLocalDatabase](../interfaces/BucketStorageAdapter.md#synclocaldatabase) + +#### Defined in + +[client/sync/bucket/SqliteBucketStorage.ts:123](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/SqliteBucketStorage.ts#L123) + +___ + +### updateLocalTarget + +▸ **updateLocalTarget**(`cb`): `Promise`<`boolean`\> + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `cb` | () => `Promise`<`string`\> | + +#### Returns + +`Promise`<`boolean`\> + +#### Implementation of + +[BucketStorageAdapter](../interfaces/BucketStorageAdapter.md).[updateLocalTarget](../interfaces/BucketStorageAdapter.md#updatelocaltarget) + +#### Defined in + +[client/sync/bucket/SqliteBucketStorage.ts:241](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/SqliteBucketStorage.ts#L241) + +___ + +### updateObjectsFromBuckets + +▸ **updateObjectsFromBuckets**(`checkpoint`): `Promise`<`boolean`\> + +Atomically update the local state to the current checkpoint. + +This includes creating new tables, dropping old tables, and copying data over from the oplog. + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `checkpoint` | [`Checkpoint`](../interfaces/Checkpoint.md) | + +#### Returns + +`Promise`<`boolean`\> + +#### Defined in + +[client/sync/bucket/SqliteBucketStorage.ts:164](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/SqliteBucketStorage.ts#L164) + +___ + +### validateChecksums + +▸ **validateChecksums**(`checkpoint`): `Promise`<[`SyncLocalDatabaseResult`](../interfaces/SyncLocalDatabaseResult.md)\> + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `checkpoint` | [`Checkpoint`](../interfaces/Checkpoint.md) | + +#### Returns + +`Promise`<[`SyncLocalDatabaseResult`](../interfaces/SyncLocalDatabaseResult.md)\> + +#### Defined in + +[client/sync/bucket/SqliteBucketStorage.ts:174](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/SqliteBucketStorage.ts#L174) + +___ + +### writeTransaction + +▸ **writeTransaction**<`T`\>(`callback`, `options?`): `Promise`<`T`\> + +#### Type parameters + +| Name | +| :------ | +| `T` | + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `callback` | (`tx`: [`Transaction`](../interfaces/Transaction.md)) => `Promise`<`T`\> | +| `options?` | `Object` | +| `options.timeoutMs` | `number` | + +#### Returns + +`Promise`<`T`\> + +#### Defined in + +[client/sync/bucket/SqliteBucketStorage.ts:333](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/SqliteBucketStorage.ts#L333) diff --git a/docs/docs/common-sdk/classes/SyncDataBatch.md b/docs/docs/common-sdk/classes/SyncDataBatch.md new file mode 100644 index 00000000..a074faba --- /dev/null +++ b/docs/docs/common-sdk/classes/SyncDataBatch.md @@ -0,0 +1,57 @@ +--- +id: "SyncDataBatch" +title: "Class: SyncDataBatch" +sidebar_label: "SyncDataBatch" +sidebar_position: 0 +custom_edit_url: null +--- + +## Constructors + +### constructor + +• **new SyncDataBatch**(`buckets`): [`SyncDataBatch`](SyncDataBatch.md) + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `buckets` | [`SyncDataBucket`](SyncDataBucket.md)[] | + +#### Returns + +[`SyncDataBatch`](SyncDataBatch.md) + +#### Defined in + +[client/sync/bucket/SyncDataBatch.ts:10](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/SyncDataBatch.ts#L10) + +## Properties + +### buckets + +• **buckets**: [`SyncDataBucket`](SyncDataBucket.md)[] + +#### Defined in + +[client/sync/bucket/SyncDataBatch.ts:10](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/SyncDataBatch.ts#L10) + +## Methods + +### fromJSON + +▸ **fromJSON**(`json`): [`SyncDataBatch`](SyncDataBatch.md) + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `json` | `any` | + +#### Returns + +[`SyncDataBatch`](SyncDataBatch.md) + +#### Defined in + +[client/sync/bucket/SyncDataBatch.ts:6](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/SyncDataBatch.ts#L6) diff --git a/docs/docs/common-sdk/classes/SyncDataBucket.md b/docs/docs/common-sdk/classes/SyncDataBucket.md new file mode 100644 index 00000000..3ed0fc4b --- /dev/null +++ b/docs/docs/common-sdk/classes/SyncDataBucket.md @@ -0,0 +1,121 @@ +--- +id: "SyncDataBucket" +title: "Class: SyncDataBucket" +sidebar_label: "SyncDataBucket" +sidebar_position: 0 +custom_edit_url: null +--- + +## Constructors + +### constructor + +• **new SyncDataBucket**(`bucket`, `data`, `has_more`, `after`, `next_after`): [`SyncDataBucket`](SyncDataBucket.md) + +#### Parameters + +| Name | Type | Description | +| :------ | :------ | :------ | +| `bucket` | `string` | - | +| `data` | `OplogEntry`[] | - | +| `has_more` | `boolean` | True if the response does not contain all the data for this bucket, and another request must be made. | +| `after` | `string` | The `after` specified in the request. | +| `next_after` | `string` | Use this for the next request. | + +#### Returns + +[`SyncDataBucket`](SyncDataBucket.md) + +#### Defined in + +[client/sync/bucket/SyncDataBucket.ts:25](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/SyncDataBucket.ts#L25) + +## Properties + +### after + +• **after**: `string` + +The `after` specified in the request. + +#### Defined in + +[client/sync/bucket/SyncDataBucket.ts:35](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/SyncDataBucket.ts#L35) + +___ + +### bucket + +• **bucket**: `string` + +#### Defined in + +[client/sync/bucket/SyncDataBucket.ts:26](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/SyncDataBucket.ts#L26) + +___ + +### data + +• **data**: `OplogEntry`[] + +#### Defined in + +[client/sync/bucket/SyncDataBucket.ts:27](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/SyncDataBucket.ts#L27) + +___ + +### has\_more + +• **has\_more**: `boolean` + +True if the response does not contain all the data for this bucket, and another request must be made. + +#### Defined in + +[client/sync/bucket/SyncDataBucket.ts:31](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/SyncDataBucket.ts#L31) + +___ + +### next\_after + +• **next\_after**: `string` + +Use this for the next request. + +#### Defined in + +[client/sync/bucket/SyncDataBucket.ts:39](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/SyncDataBucket.ts#L39) + +## Methods + +### toJSON + +▸ **toJSON**(): [`SyncDataBucketJSON`](../modules.md#syncdatabucketjson) + +#### Returns + +[`SyncDataBucketJSON`](../modules.md#syncdatabucketjson) + +#### Defined in + +[client/sync/bucket/SyncDataBucket.ts:42](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/SyncDataBucket.ts#L42) + +___ + +### fromRow + +▸ **fromRow**(`row`): [`SyncDataBucket`](SyncDataBucket.md) + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `row` | [`SyncDataBucketJSON`](../modules.md#syncdatabucketjson) | + +#### Returns + +[`SyncDataBucket`](SyncDataBucket.md) + +#### Defined in + +[client/sync/bucket/SyncDataBucket.ts:15](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/SyncDataBucket.ts#L15) diff --git a/docs/docs/common-sdk/classes/SyncStatus.md b/docs/docs/common-sdk/classes/SyncStatus.md new file mode 100644 index 00000000..5929079b --- /dev/null +++ b/docs/docs/common-sdk/classes/SyncStatus.md @@ -0,0 +1,62 @@ +--- +id: "SyncStatus" +title: "Class: SyncStatus" +sidebar_label: "SyncStatus" +sidebar_position: 0 +custom_edit_url: null +--- + +## Constructors + +### constructor + +• **new SyncStatus**(`connected`, `lastSyncedAt`): [`SyncStatus`](SyncStatus.md) + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `connected` | `boolean` | +| `lastSyncedAt` | `Date` | + +#### Returns + +[`SyncStatus`](SyncStatus.md) + +#### Defined in + +[db/crud/SyncStatus.ts:2](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/db/crud/SyncStatus.ts#L2) + +## Properties + +### connected + +• **connected**: `boolean` + +#### Defined in + +[db/crud/SyncStatus.ts:2](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/db/crud/SyncStatus.ts#L2) + +___ + +### lastSyncedAt + +• **lastSyncedAt**: `Date` + +#### Defined in + +[db/crud/SyncStatus.ts:2](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/db/crud/SyncStatus.ts#L2) + +## Methods + +### getMessage + +▸ **getMessage**(): `string` + +#### Returns + +`string` + +#### Defined in + +[db/crud/SyncStatus.ts:4](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/db/crud/SyncStatus.ts#L4) diff --git a/docs/docs/common-sdk/classes/Table.md b/docs/docs/common-sdk/classes/Table.md new file mode 100644 index 00000000..2decc8c1 --- /dev/null +++ b/docs/docs/common-sdk/classes/Table.md @@ -0,0 +1,197 @@ +--- +id: "Table" +title: "Class: Table" +sidebar_label: "Table" +sidebar_position: 0 +custom_edit_url: null +--- + +## Constructors + +### constructor + +• **new Table**(`options`): [`Table`](Table.md) + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `options` | [`TableOptions`](../interfaces/TableOptions.md) | + +#### Returns + +[`Table`](Table.md) + +#### Defined in + +[db/schema/Table.ts:29](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/db/schema/Table.ts#L29) + +## Properties + +### options + +• `Protected` **options**: [`TableOptions`](../interfaces/TableOptions.md) + +#### Defined in + +[db/schema/Table.ts:19](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/db/schema/Table.ts#L19) + +## Accessors + +### columns + +• `get` **columns**(): [`Column`](Column.md)[] + +#### Returns + +[`Column`](Column.md)[] + +#### Defined in + +[db/schema/Table.ts:37](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/db/schema/Table.ts#L37) + +___ + +### indexes + +• `get` **indexes**(): [`Index`](Index.md)[] + +#### Returns + +[`Index`](Index.md)[] + +#### Defined in + +[db/schema/Table.ts:41](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/db/schema/Table.ts#L41) + +___ + +### insertOnly + +• `get` **insertOnly**(): `boolean` + +#### Returns + +`boolean` + +#### Defined in + +[db/schema/Table.ts:49](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/db/schema/Table.ts#L49) + +___ + +### internalName + +• `get` **internalName**(): `string` + +#### Returns + +`string` + +#### Defined in + +[db/schema/Table.ts:53](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/db/schema/Table.ts#L53) + +___ + +### localOnly + +• `get` **localOnly**(): `boolean` + +#### Returns + +`boolean` + +#### Defined in + +[db/schema/Table.ts:45](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/db/schema/Table.ts#L45) + +___ + +### name + +• `get` **name**(): `string` + +#### Returns + +`string` + +#### Defined in + +[db/schema/Table.ts:33](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/db/schema/Table.ts#L33) + +___ + +### validName + +• `get` **validName**(): `boolean` + +#### Returns + +`boolean` + +#### Defined in + +[db/schema/Table.ts:61](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/db/schema/Table.ts#L61) + +## Methods + +### toJSON + +▸ **toJSON**(): `Object` + +#### Returns + +`Object` + +| Name | Type | +| :------ | :------ | +| `columns` | \{ `name`: `string` ; `type`: [`ColumnType`](../enums/ColumnType.md) }[] | +| `indexes` | \{ `columns`: \{ `ascending`: `boolean` ; `name`: `string` ; `type`: [`ColumnType`](../enums/ColumnType.md) }[] ; `name`: `string` }[] | +| `insert_only` | `boolean` | +| `local_only` | `boolean` | +| `name` | `string` | + +#### Defined in + +[db/schema/Table.ts:66](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/db/schema/Table.ts#L66) + +___ + +### createInsertOnly + +▸ **createInsertOnly**(`options`): [`Table`](Table.md) + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `options` | [`TableOptions`](../interfaces/TableOptions.md) | + +#### Returns + +[`Table`](Table.md) + +#### Defined in + +[db/schema/Table.ts:25](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/db/schema/Table.ts#L25) + +___ + +### createLocalOnly + +▸ **createLocalOnly**(`options`): [`Table`](Table.md) + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `options` | [`TableOptions`](../interfaces/TableOptions.md) | + +#### Returns + +[`Table`](Table.md) + +#### Defined in + +[db/schema/Table.ts:21](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/db/schema/Table.ts#L21) diff --git a/docs/docs/common-sdk/classes/UploadQueueStats.md b/docs/docs/common-sdk/classes/UploadQueueStats.md new file mode 100644 index 00000000..68c2ad3b --- /dev/null +++ b/docs/docs/common-sdk/classes/UploadQueueStats.md @@ -0,0 +1,62 @@ +--- +id: "UploadQueueStats" +title: "Class: UploadQueueStats" +sidebar_label: "UploadQueueStats" +sidebar_position: 0 +custom_edit_url: null +--- + +## Constructors + +### constructor + +• **new UploadQueueStats**(`count`, `size?`): [`UploadQueueStats`](UploadQueueStats.md) + +#### Parameters + +| Name | Type | Default value | +| :------ | :------ | :------ | +| `count` | `number` | `undefined` | +| `size` | `number` | `null` | + +#### Returns + +[`UploadQueueStats`](UploadQueueStats.md) + +#### Defined in + +[db/crud/UploadQueueStatus.ts:2](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/db/crud/UploadQueueStatus.ts#L2) + +## Properties + +### count + +• **count**: `number` + +#### Defined in + +[db/crud/UploadQueueStatus.ts:2](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/db/crud/UploadQueueStatus.ts#L2) + +___ + +### size + +• **size**: `number` = `null` + +#### Defined in + +[db/crud/UploadQueueStatus.ts:2](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/db/crud/UploadQueueStatus.ts#L2) + +## Methods + +### toString + +▸ **toString**(): `string` + +#### Returns + +`string` + +#### Defined in + +[db/crud/UploadQueueStatus.ts:4](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/db/crud/UploadQueueStatus.ts#L4) diff --git a/docs/docs/common-sdk/classes/_category_.yml b/docs/docs/common-sdk/classes/_category_.yml new file mode 100644 index 00000000..55c7980a --- /dev/null +++ b/docs/docs/common-sdk/classes/_category_.yml @@ -0,0 +1,2 @@ +label: "Classes" +position: 3 \ No newline at end of file diff --git a/docs/docs/common-sdk/enums/ColumnType.md b/docs/docs/common-sdk/enums/ColumnType.md new file mode 100644 index 00000000..e257adbb --- /dev/null +++ b/docs/docs/common-sdk/enums/ColumnType.md @@ -0,0 +1,37 @@ +--- +id: "ColumnType" +title: "Enumeration: ColumnType" +sidebar_label: "ColumnType" +sidebar_position: 0 +custom_edit_url: null +--- + +## Enumeration Members + +### INTEGER + +• **INTEGER** = ``"INTEGER"`` + +#### Defined in + +[db/Column.ts:4](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/db/Column.ts#L4) + +___ + +### REAL + +• **REAL** = ``"REAL"`` + +#### Defined in + +[db/Column.ts:5](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/db/Column.ts#L5) + +___ + +### TEXT + +• **TEXT** = ``"TEXT"`` + +#### Defined in + +[db/Column.ts:3](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/db/Column.ts#L3) diff --git a/docs/docs/common-sdk/enums/LockType.md b/docs/docs/common-sdk/enums/LockType.md new file mode 100644 index 00000000..c72f1cb1 --- /dev/null +++ b/docs/docs/common-sdk/enums/LockType.md @@ -0,0 +1,27 @@ +--- +id: "LockType" +title: "Enumeration: LockType" +sidebar_label: "LockType" +sidebar_position: 0 +custom_edit_url: null +--- + +## Enumeration Members + +### CRUD + +• **CRUD** = ``"crud"`` + +#### Defined in + +[client/sync/stream/AbstractStreamingSyncImplementation.ts:22](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/stream/AbstractStreamingSyncImplementation.ts#L22) + +___ + +### SYNC + +• **SYNC** = ``"sync"`` + +#### Defined in + +[client/sync/stream/AbstractStreamingSyncImplementation.ts:23](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/stream/AbstractStreamingSyncImplementation.ts#L23) diff --git a/docs/docs/common-sdk/enums/OpTypeEnum.md b/docs/docs/common-sdk/enums/OpTypeEnum.md new file mode 100644 index 00000000..10d4f014 --- /dev/null +++ b/docs/docs/common-sdk/enums/OpTypeEnum.md @@ -0,0 +1,47 @@ +--- +id: "OpTypeEnum" +title: "Enumeration: OpTypeEnum" +sidebar_label: "OpTypeEnum" +sidebar_position: 0 +custom_edit_url: null +--- + +## Enumeration Members + +### CLEAR + +• **CLEAR** = ``1`` + +#### Defined in + +[client/sync/bucket/OpType.ts:2](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/OpType.ts#L2) + +___ + +### MOVE + +• **MOVE** = ``2`` + +#### Defined in + +[client/sync/bucket/OpType.ts:3](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/OpType.ts#L3) + +___ + +### PUT + +• **PUT** = ``3`` + +#### Defined in + +[client/sync/bucket/OpType.ts:4](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/OpType.ts#L4) + +___ + +### REMOVE + +• **REMOVE** = ``4`` + +#### Defined in + +[client/sync/bucket/OpType.ts:5](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/OpType.ts#L5) diff --git a/docs/docs/common-sdk/enums/RowUpdateType.md b/docs/docs/common-sdk/enums/RowUpdateType.md new file mode 100644 index 00000000..00c7762e --- /dev/null +++ b/docs/docs/common-sdk/enums/RowUpdateType.md @@ -0,0 +1,39 @@ +--- +id: "RowUpdateType" +title: "Enumeration: RowUpdateType" +sidebar_label: "RowUpdateType" +sidebar_position: 0 +custom_edit_url: null +--- + +Update table operation numbers from SQLite + +## Enumeration Members + +### SQLITE\_DELETE + +• **SQLITE\_DELETE** = ``9`` + +#### Defined in + +[db/DBAdapter.ts:54](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/db/DBAdapter.ts#L54) + +___ + +### SQLITE\_INSERT + +• **SQLITE\_INSERT** = ``18`` + +#### Defined in + +[db/DBAdapter.ts:53](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/db/DBAdapter.ts#L53) + +___ + +### SQLITE\_UPDATE + +• **SQLITE\_UPDATE** = ``23`` + +#### Defined in + +[db/DBAdapter.ts:55](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/db/DBAdapter.ts#L55) diff --git a/docs/docs/common-sdk/enums/UpdateType.md b/docs/docs/common-sdk/enums/UpdateType.md new file mode 100644 index 00000000..28fc2286 --- /dev/null +++ b/docs/docs/common-sdk/enums/UpdateType.md @@ -0,0 +1,37 @@ +--- +id: "UpdateType" +title: "Enumeration: UpdateType" +sidebar_label: "UpdateType" +sidebar_position: 0 +custom_edit_url: null +--- + +## Enumeration Members + +### DELETE + +• **DELETE** = ``"DELETE"`` + +#### Defined in + +[client/sync/bucket/CrudEntry.ts:13](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/CrudEntry.ts#L13) + +___ + +### PATCH + +• **PATCH** = ``"PATCH"`` + +#### Defined in + +[client/sync/bucket/CrudEntry.ts:12](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/CrudEntry.ts#L12) + +___ + +### PUT + +• **PUT** = ``"PUT"`` + +#### Defined in + +[client/sync/bucket/CrudEntry.ts:11](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/CrudEntry.ts#L11) diff --git a/docs/docs/common-sdk/enums/_category_.yml b/docs/docs/common-sdk/enums/_category_.yml new file mode 100644 index 00000000..1687a9e0 --- /dev/null +++ b/docs/docs/common-sdk/enums/_category_.yml @@ -0,0 +1,2 @@ +label: "Enumerations" +position: 2 \ No newline at end of file diff --git a/docs/docs/common-sdk/index.md b/docs/docs/common-sdk/index.md new file mode 100644 index 00000000..ab84754b --- /dev/null +++ b/docs/docs/common-sdk/index.md @@ -0,0 +1,14 @@ +--- +id: "index" +title: "@journeyapps/powersync-sdk-common" +sidebar_label: "Readme" +sidebar_position: 0 +custom_edit_url: null +--- + +# Beta +This package is currently in a beta release. + +# PowerSync SDK common JS + +This package contains pure TypeScript common functionality for the PowerSync SDK. diff --git a/docs/docs/common-sdk/interfaces/AbstractStreamingSyncImplementationOptions.md b/docs/docs/common-sdk/interfaces/AbstractStreamingSyncImplementationOptions.md new file mode 100644 index 00000000..e9cc28b7 --- /dev/null +++ b/docs/docs/common-sdk/interfaces/AbstractStreamingSyncImplementationOptions.md @@ -0,0 +1,65 @@ +--- +id: "AbstractStreamingSyncImplementationOptions" +title: "Interface: AbstractStreamingSyncImplementationOptions" +sidebar_label: "AbstractStreamingSyncImplementationOptions" +sidebar_position: 0 +custom_edit_url: null +--- + +## Properties + +### adapter + +• **adapter**: [`BucketStorageAdapter`](BucketStorageAdapter.md) + +#### Defined in + +[client/sync/stream/AbstractStreamingSyncImplementation.ts:35](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/stream/AbstractStreamingSyncImplementation.ts#L35) + +___ + +### logger + +• `Optional` **logger**: `ILogger` + +#### Defined in + +[client/sync/stream/AbstractStreamingSyncImplementation.ts:38](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/stream/AbstractStreamingSyncImplementation.ts#L38) + +___ + +### remote + +• **remote**: [`AbstractRemote`](../classes/AbstractRemote.md) + +#### Defined in + +[client/sync/stream/AbstractStreamingSyncImplementation.ts:36](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/stream/AbstractStreamingSyncImplementation.ts#L36) + +___ + +### retryDelayMs + +• `Optional` **retryDelayMs**: `number` + +#### Defined in + +[client/sync/stream/AbstractStreamingSyncImplementation.ts:39](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/stream/AbstractStreamingSyncImplementation.ts#L39) + +___ + +### uploadCrud + +• **uploadCrud**: () => `Promise`<`void`\> + +#### Type declaration + +▸ (): `Promise`<`void`\> + +##### Returns + +`Promise`<`void`\> + +#### Defined in + +[client/sync/stream/AbstractStreamingSyncImplementation.ts:37](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/stream/AbstractStreamingSyncImplementation.ts#L37) diff --git a/docs/docs/common-sdk/interfaces/BaseObserverInterface.md b/docs/docs/common-sdk/interfaces/BaseObserverInterface.md new file mode 100644 index 00000000..bc5e4527 --- /dev/null +++ b/docs/docs/common-sdk/interfaces/BaseObserverInterface.md @@ -0,0 +1,49 @@ +--- +id: "BaseObserverInterface" +title: "Interface: BaseObserverInterface" +sidebar_label: "BaseObserverInterface" +sidebar_position: 0 +custom_edit_url: null +--- + +## Type parameters + +| Name | Type | +| :------ | :------ | +| `T` | extends [`BaseListener`](../modules.md#baselistener) | + +## Hierarchy + +- **`BaseObserverInterface`** + + ↳ [`DBAdapter`](DBAdapter.md) + +## Implemented by + +- [`BaseObserver`](../classes/BaseObserver.md) + +## Methods + +### registerListener + +▸ **registerListener**(`listener`): () => `void` + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `listener` | `Partial`<`T`\> | + +#### Returns + +`fn` + +▸ (): `void` + +##### Returns + +`void` + +#### Defined in + +[utils/BaseObserver.ts:4](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/utils/BaseObserver.ts#L4) diff --git a/docs/docs/common-sdk/interfaces/BucketChecksum.md b/docs/docs/common-sdk/interfaces/BucketChecksum.md new file mode 100644 index 00000000..abe606cb --- /dev/null +++ b/docs/docs/common-sdk/interfaces/BucketChecksum.md @@ -0,0 +1,41 @@ +--- +id: "BucketChecksum" +title: "Interface: BucketChecksum" +sidebar_label: "BucketChecksum" +sidebar_position: 0 +custom_edit_url: null +--- + +## Properties + +### bucket + +• **bucket**: `string` + +#### Defined in + +[client/sync/bucket/BucketStorageAdapter.ts:28](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/BucketStorageAdapter.ts#L28) + +___ + +### checksum + +• **checksum**: `number` + +32-bit unsigned hash. + +#### Defined in + +[client/sync/bucket/BucketStorageAdapter.ts:32](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/BucketStorageAdapter.ts#L32) + +___ + +### count + +• **count**: `number` + +Count of operations - informational only. + +#### Defined in + +[client/sync/bucket/BucketStorageAdapter.ts:37](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/BucketStorageAdapter.ts#L37) diff --git a/docs/docs/common-sdk/interfaces/BucketRequest.md b/docs/docs/common-sdk/interfaces/BucketRequest.md new file mode 100644 index 00000000..2326a675 --- /dev/null +++ b/docs/docs/common-sdk/interfaces/BucketRequest.md @@ -0,0 +1,29 @@ +--- +id: "BucketRequest" +title: "Interface: BucketRequest" +sidebar_label: "BucketRequest" +sidebar_position: 0 +custom_edit_url: null +--- + +## Properties + +### after + +• **after**: `string` + +Base-10 number. Sync all data from this bucket with op_id > after. + +#### Defined in + +[client/sync/stream/streaming-sync-types.ts:121](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/stream/streaming-sync-types.ts#L121) + +___ + +### name + +• **name**: `string` + +#### Defined in + +[client/sync/stream/streaming-sync-types.ts:116](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/stream/streaming-sync-types.ts#L116) diff --git a/docs/docs/common-sdk/interfaces/BucketState.md b/docs/docs/common-sdk/interfaces/BucketState.md new file mode 100644 index 00000000..4b3ef520 --- /dev/null +++ b/docs/docs/common-sdk/interfaces/BucketState.md @@ -0,0 +1,27 @@ +--- +id: "BucketState" +title: "Interface: BucketState" +sidebar_label: "BucketState" +sidebar_position: 0 +custom_edit_url: null +--- + +## Properties + +### bucket + +• **bucket**: `string` + +#### Defined in + +[client/sync/bucket/BucketStorageAdapter.ts:12](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/BucketStorageAdapter.ts#L12) + +___ + +### op\_id + +• **op\_id**: `string` + +#### Defined in + +[client/sync/bucket/BucketStorageAdapter.ts:13](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/BucketStorageAdapter.ts#L13) diff --git a/docs/docs/common-sdk/interfaces/BucketStorageAdapter.md b/docs/docs/common-sdk/interfaces/BucketStorageAdapter.md new file mode 100644 index 00000000..2fa3b339 --- /dev/null +++ b/docs/docs/common-sdk/interfaces/BucketStorageAdapter.md @@ -0,0 +1,247 @@ +--- +id: "BucketStorageAdapter" +title: "Interface: BucketStorageAdapter" +sidebar_label: "BucketStorageAdapter" +sidebar_position: 0 +custom_edit_url: null +--- + +## Implemented by + +- [`SqliteBucketStorage`](../classes/SqliteBucketStorage.md) + +## Methods + +### autoCompact + +▸ **autoCompact**(): `Promise`<`void`\> + +Exposed for tests only. + +#### Returns + +`Promise`<`void`\> + +#### Defined in + +[client/sync/bucket/BucketStorageAdapter.ts:60](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/BucketStorageAdapter.ts#L60) + +___ + +### forceCompact + +▸ **forceCompact**(): `Promise`<`void`\> + +Exposed for tests only. + +#### Returns + +`Promise`<`void`\> + +#### Defined in + +[client/sync/bucket/BucketStorageAdapter.ts:65](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/BucketStorageAdapter.ts#L65) + +___ + +### getBucketStates + +▸ **getBucketStates**(): `Promise`<[`BucketState`](BucketState.md)[]\> + +#### Returns + +`Promise`<[`BucketState`](BucketState.md)[]\> + +#### Defined in + +[client/sync/bucket/BucketStorageAdapter.ts:48](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/BucketStorageAdapter.ts#L48) + +___ + +### getCrudBatch + +▸ **getCrudBatch**(`limit?`): `Promise`<[`CrudBatch`](../classes/CrudBatch.md)\> + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `limit?` | `number` | + +#### Returns + +`Promise`<[`CrudBatch`](../classes/CrudBatch.md)\> + +#### Defined in + +[client/sync/bucket/BucketStorageAdapter.ts:53](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/BucketStorageAdapter.ts#L53) + +___ + +### getMaxOpId + +▸ **getMaxOpId**(): `string` + +#### Returns + +`string` + +#### Defined in + +[client/sync/bucket/BucketStorageAdapter.ts:67](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/BucketStorageAdapter.ts#L67) + +___ + +### hasCompletedSync + +▸ **hasCompletedSync**(): `Promise`<`boolean`\> + +#### Returns + +`Promise`<`boolean`\> + +#### Defined in + +[client/sync/bucket/BucketStorageAdapter.ts:55](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/BucketStorageAdapter.ts#L55) + +___ + +### hasCrud + +▸ **hasCrud**(): `Promise`<`boolean`\> + +#### Returns + +`Promise`<`boolean`\> + +#### Defined in + +[client/sync/bucket/BucketStorageAdapter.ts:52](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/BucketStorageAdapter.ts#L52) + +___ + +### init + +▸ **init**(): `Promise`<`void`\> + +#### Returns + +`Promise`<`void`\> + +#### Defined in + +[client/sync/bucket/BucketStorageAdapter.ts:41](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/BucketStorageAdapter.ts#L41) + +___ + +### removeBuckets + +▸ **removeBuckets**(`buckets`): `Promise`<`void`\> + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `buckets` | `string`[] | + +#### Returns + +`Promise`<`void`\> + +#### Defined in + +[client/sync/bucket/BucketStorageAdapter.ts:43](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/BucketStorageAdapter.ts#L43) + +___ + +### saveSyncData + +▸ **saveSyncData**(`batch`): `Promise`<`void`\> + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `batch` | [`SyncDataBatch`](../classes/SyncDataBatch.md) | + +#### Returns + +`Promise`<`void`\> + +#### Defined in + +[client/sync/bucket/BucketStorageAdapter.ts:42](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/BucketStorageAdapter.ts#L42) + +___ + +### setTargetCheckpoint + +▸ **setTargetCheckpoint**(`checkpoint`): `Promise`<`void`\> + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `checkpoint` | [`Checkpoint`](Checkpoint.md) | + +#### Returns + +`Promise`<`void`\> + +#### Defined in + +[client/sync/bucket/BucketStorageAdapter.ts:44](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/BucketStorageAdapter.ts#L44) + +___ + +### startSession + +▸ **startSession**(): `void` + +#### Returns + +`void` + +#### Defined in + +[client/sync/bucket/BucketStorageAdapter.ts:46](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/BucketStorageAdapter.ts#L46) + +___ + +### syncLocalDatabase + +▸ **syncLocalDatabase**(`checkpoint`): `Promise`<\{ `checkpointValid`: `boolean` ; `failures?`: `any`[] ; `ready`: `boolean` }\> + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `checkpoint` | [`Checkpoint`](Checkpoint.md) | + +#### Returns + +`Promise`<\{ `checkpointValid`: `boolean` ; `failures?`: `any`[] ; `ready`: `boolean` }\> + +#### Defined in + +[client/sync/bucket/BucketStorageAdapter.ts:50](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/BucketStorageAdapter.ts#L50) + +___ + +### updateLocalTarget + +▸ **updateLocalTarget**(`cb`): `Promise`<`boolean`\> + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `cb` | () => `Promise`<`string`\> | + +#### Returns + +`Promise`<`boolean`\> + +#### Defined in + +[client/sync/bucket/BucketStorageAdapter.ts:56](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/BucketStorageAdapter.ts#L56) diff --git a/docs/docs/common-sdk/interfaces/Checkpoint.md b/docs/docs/common-sdk/interfaces/Checkpoint.md new file mode 100644 index 00000000..cdf10572 --- /dev/null +++ b/docs/docs/common-sdk/interfaces/Checkpoint.md @@ -0,0 +1,37 @@ +--- +id: "Checkpoint" +title: "Interface: Checkpoint" +sidebar_label: "Checkpoint" +sidebar_position: 0 +custom_edit_url: null +--- + +## Properties + +### buckets + +• **buckets**: [`BucketChecksum`](BucketChecksum.md)[] + +#### Defined in + +[client/sync/bucket/BucketStorageAdapter.ts:7](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/BucketStorageAdapter.ts#L7) + +___ + +### last\_op\_id + +• **last\_op\_id**: `string` + +#### Defined in + +[client/sync/bucket/BucketStorageAdapter.ts:6](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/BucketStorageAdapter.ts#L6) + +___ + +### write\_checkpoint + +• `Optional` **write\_checkpoint**: `string` + +#### Defined in + +[client/sync/bucket/BucketStorageAdapter.ts:8](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/BucketStorageAdapter.ts#L8) diff --git a/docs/docs/common-sdk/interfaces/ChecksumCache.md b/docs/docs/common-sdk/interfaces/ChecksumCache.md new file mode 100644 index 00000000..e0e557c7 --- /dev/null +++ b/docs/docs/common-sdk/interfaces/ChecksumCache.md @@ -0,0 +1,27 @@ +--- +id: "ChecksumCache" +title: "Interface: ChecksumCache" +sidebar_label: "ChecksumCache" +sidebar_position: 0 +custom_edit_url: null +--- + +## Properties + +### checksums + +• **checksums**: `Map`<`string`, \{ `checksum`: [`BucketChecksum`](BucketChecksum.md) ; `last_op_id`: `string` }\> + +#### Defined in + +[client/sync/bucket/BucketStorageAdapter.ts:17](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/BucketStorageAdapter.ts#L17) + +___ + +### lastOpId + +• **lastOpId**: `string` + +#### Defined in + +[client/sync/bucket/BucketStorageAdapter.ts:18](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/BucketStorageAdapter.ts#L18) diff --git a/docs/docs/common-sdk/interfaces/ColumnOptions.md b/docs/docs/common-sdk/interfaces/ColumnOptions.md new file mode 100644 index 00000000..9c5f3af8 --- /dev/null +++ b/docs/docs/common-sdk/interfaces/ColumnOptions.md @@ -0,0 +1,27 @@ +--- +id: "ColumnOptions" +title: "Interface: ColumnOptions" +sidebar_label: "ColumnOptions" +sidebar_position: 0 +custom_edit_url: null +--- + +## Properties + +### name + +• **name**: `string` + +#### Defined in + +[db/Column.ts:9](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/db/Column.ts#L9) + +___ + +### type + +• `Optional` **type**: [`ColumnType`](../enums/ColumnType.md) + +#### Defined in + +[db/Column.ts:10](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/db/Column.ts#L10) diff --git a/docs/docs/common-sdk/interfaces/ContinueCheckpointRequest.md b/docs/docs/common-sdk/interfaces/ContinueCheckpointRequest.md new file mode 100644 index 00000000..cbfb5112 --- /dev/null +++ b/docs/docs/common-sdk/interfaces/ContinueCheckpointRequest.md @@ -0,0 +1,41 @@ +--- +id: "ContinueCheckpointRequest" +title: "Interface: ContinueCheckpointRequest" +sidebar_label: "ContinueCheckpointRequest" +sidebar_position: 0 +custom_edit_url: null +--- + +For sync2.json + +## Properties + +### buckets + +• **buckets**: [`BucketRequest`](BucketRequest.md)[] + +Existing bucket states. Only these buckets are synchronized. + +#### Defined in + +[client/sync/stream/streaming-sync-types.ts:12](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/stream/streaming-sync-types.ts#L12) + +___ + +### checkpoint\_token + +• **checkpoint\_token**: `string` + +#### Defined in + +[client/sync/stream/streaming-sync-types.ts:14](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/stream/streaming-sync-types.ts#L14) + +___ + +### limit + +• `Optional` **limit**: `number` + +#### Defined in + +[client/sync/stream/streaming-sync-types.ts:16](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/stream/streaming-sync-types.ts#L16) diff --git a/docs/docs/common-sdk/interfaces/CrudRequest.md b/docs/docs/common-sdk/interfaces/CrudRequest.md new file mode 100644 index 00000000..e377ceb8 --- /dev/null +++ b/docs/docs/common-sdk/interfaces/CrudRequest.md @@ -0,0 +1,19 @@ +--- +id: "CrudRequest" +title: "Interface: CrudRequest" +sidebar_label: "CrudRequest" +sidebar_position: 0 +custom_edit_url: null +--- + +For crud.json + +## Properties + +### data + +• **data**: [`CrudEntry`](../classes/CrudEntry.md)[] + +#### Defined in + +[client/sync/stream/streaming-sync-types.ts:159](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/stream/streaming-sync-types.ts#L159) diff --git a/docs/docs/common-sdk/interfaces/CrudResponse.md b/docs/docs/common-sdk/interfaces/CrudResponse.md new file mode 100644 index 00000000..7cbb9987 --- /dev/null +++ b/docs/docs/common-sdk/interfaces/CrudResponse.md @@ -0,0 +1,23 @@ +--- +id: "CrudResponse" +title: "Interface: CrudResponse" +sidebar_label: "CrudResponse" +sidebar_position: 0 +custom_edit_url: null +--- + +## Properties + +### checkpoint + +• `Optional` **checkpoint**: `string` + +A sync response with a checkpoint >= this checkpoint would contain all the changes in this request. + +Any earlier checkpoint may or may not contain these changes. + +May be empty when the request contains no ops. + +#### Defined in + +[client/sync/stream/streaming-sync-types.ts:170](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/stream/streaming-sync-types.ts#L170) diff --git a/docs/docs/common-sdk/interfaces/DBAdapter.md b/docs/docs/common-sdk/interfaces/DBAdapter.md new file mode 100644 index 00000000..499fe6cc --- /dev/null +++ b/docs/docs/common-sdk/interfaces/DBAdapter.md @@ -0,0 +1,305 @@ +--- +id: "DBAdapter" +title: "Interface: DBAdapter" +sidebar_label: "DBAdapter" +sidebar_position: 0 +custom_edit_url: null +--- + +## Hierarchy + +- [`BaseObserverInterface`](BaseObserverInterface.md)<[`DBAdapterListener`](DBAdapterListener.md)\> + +- [`DBGetUtils`](DBGetUtils.md) + + ↳ **`DBAdapter`** + +## Properties + +### close + +• **close**: () => `void` + +#### Type declaration + +▸ (): `void` + +##### Returns + +`void` + +#### Defined in + +[db/DBAdapter.ts:72](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/db/DBAdapter.ts#L72) + +___ + +### execute + +• **execute**: (`query`: `string`, `params?`: `any`[]) => `Promise`<[`QueryResult`](QueryResult.md)\> + +#### Type declaration + +▸ (`query`, `params?`): `Promise`<[`QueryResult`](QueryResult.md)\> + +##### Parameters + +| Name | Type | +| :------ | :------ | +| `query` | `string` | +| `params?` | `any`[] | + +##### Returns + +`Promise`<[`QueryResult`](QueryResult.md)\> + +#### Defined in + +[db/DBAdapter.ts:77](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/db/DBAdapter.ts#L77) + +___ + +### readLock + +• **readLock**: (`fn`: (`tx`: [`LockContext`](LockContext.md)) => `Promise`<`T`\>, `options?`: [`DBLockOptions`](DBLockOptions.md)) => `Promise`<`T`\> + +#### Type declaration + +▸ <`T`\>(`fn`, `options?`): `Promise`<`T`\> + +##### Type parameters + +| Name | +| :------ | +| `T` | + +##### Parameters + +| Name | Type | +| :------ | :------ | +| `fn` | (`tx`: [`LockContext`](LockContext.md)) => `Promise`<`T`\> | +| `options?` | [`DBLockOptions`](DBLockOptions.md) | + +##### Returns + +`Promise`<`T`\> + +#### Defined in + +[db/DBAdapter.ts:73](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/db/DBAdapter.ts#L73) + +___ + +### readTransaction + +• **readTransaction**: (`fn`: (`tx`: [`Transaction`](Transaction.md)) => `Promise`<`T`\>, `options?`: [`DBLockOptions`](DBLockOptions.md)) => `Promise`<`T`\> + +#### Type declaration + +▸ <`T`\>(`fn`, `options?`): `Promise`<`T`\> + +##### Type parameters + +| Name | +| :------ | +| `T` | + +##### Parameters + +| Name | Type | +| :------ | :------ | +| `fn` | (`tx`: [`Transaction`](Transaction.md)) => `Promise`<`T`\> | +| `options?` | [`DBLockOptions`](DBLockOptions.md) | + +##### Returns + +`Promise`<`T`\> + +#### Defined in + +[db/DBAdapter.ts:74](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/db/DBAdapter.ts#L74) + +___ + +### writeLock + +• **writeLock**: (`fn`: (`tx`: [`LockContext`](LockContext.md)) => `Promise`<`T`\>, `options?`: [`DBLockOptions`](DBLockOptions.md)) => `Promise`<`T`\> + +#### Type declaration + +▸ <`T`\>(`fn`, `options?`): `Promise`<`T`\> + +##### Type parameters + +| Name | +| :------ | +| `T` | + +##### Parameters + +| Name | Type | +| :------ | :------ | +| `fn` | (`tx`: [`LockContext`](LockContext.md)) => `Promise`<`T`\> | +| `options?` | [`DBLockOptions`](DBLockOptions.md) | + +##### Returns + +`Promise`<`T`\> + +#### Defined in + +[db/DBAdapter.ts:75](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/db/DBAdapter.ts#L75) + +___ + +### writeTransaction + +• **writeTransaction**: (`fn`: (`tx`: [`Transaction`](Transaction.md)) => `Promise`<`T`\>, `options?`: [`DBLockOptions`](DBLockOptions.md)) => `Promise`<`T`\> + +#### Type declaration + +▸ <`T`\>(`fn`, `options?`): `Promise`<`T`\> + +##### Type parameters + +| Name | +| :------ | +| `T` | + +##### Parameters + +| Name | Type | +| :------ | :------ | +| `fn` | (`tx`: [`Transaction`](Transaction.md)) => `Promise`<`T`\> | +| `options?` | [`DBLockOptions`](DBLockOptions.md) | + +##### Returns + +`Promise`<`T`\> + +#### Defined in + +[db/DBAdapter.ts:76](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/db/DBAdapter.ts#L76) + +## Methods + +### get + +▸ **get**<`T`\>(`sql`, `parameters?`): `Promise`<`T`\> + +#### Type parameters + +| Name | +| :------ | +| `T` | + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `sql` | `string` | +| `parameters?` | `any`[] | + +#### Returns + +`Promise`<`T`\> + +#### Inherited from + +[DBGetUtils](DBGetUtils.md).[get](DBGetUtils.md#get) + +#### Defined in + +[db/DBAdapter.ts:37](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/db/DBAdapter.ts#L37) + +___ + +### getAll + +▸ **getAll**<`T`\>(`sql`, `parameters?`): `Promise`<`T`[]\> + +#### Type parameters + +| Name | +| :------ | +| `T` | + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `sql` | `string` | +| `parameters?` | `any`[] | + +#### Returns + +`Promise`<`T`[]\> + +#### Inherited from + +[DBGetUtils](DBGetUtils.md).[getAll](DBGetUtils.md#getall) + +#### Defined in + +[db/DBAdapter.ts:35](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/db/DBAdapter.ts#L35) + +___ + +### getOptional + +▸ **getOptional**<`T`\>(`sql`, `parameters?`): `Promise`<`T`\> + +#### Type parameters + +| Name | +| :------ | +| `T` | + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `sql` | `string` | +| `parameters?` | `any`[] | + +#### Returns + +`Promise`<`T`\> + +#### Inherited from + +[DBGetUtils](DBGetUtils.md).[getOptional](DBGetUtils.md#getoptional) + +#### Defined in + +[db/DBAdapter.ts:36](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/db/DBAdapter.ts#L36) + +___ + +### registerListener + +▸ **registerListener**(`listener`): () => `void` + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `listener` | `Partial`<[`DBAdapterListener`](DBAdapterListener.md)\> | + +#### Returns + +`fn` + +▸ (): `void` + +##### Returns + +`void` + +#### Inherited from + +[BaseObserverInterface](BaseObserverInterface.md).[registerListener](BaseObserverInterface.md#registerlistener) + +#### Defined in + +[utils/BaseObserver.ts:4](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/utils/BaseObserver.ts#L4) diff --git a/docs/docs/common-sdk/interfaces/DBAdapterListener.md b/docs/docs/common-sdk/interfaces/DBAdapterListener.md new file mode 100644 index 00000000..20ead2a1 --- /dev/null +++ b/docs/docs/common-sdk/interfaces/DBAdapterListener.md @@ -0,0 +1,37 @@ +--- +id: "DBAdapterListener" +title: "Interface: DBAdapterListener" +sidebar_label: "DBAdapterListener" +sidebar_position: 0 +custom_edit_url: null +--- + +## Hierarchy + +- [`BaseListener`](../modules.md#baselistener) + + ↳ **`DBAdapterListener`** + +## Properties + +### tablesUpdated + +• **tablesUpdated**: (`updateNotification`: [`UpdateNotification`](UpdateNotification.md)) => `void` + +#### Type declaration + +▸ (`updateNotification`): `void` + +##### Parameters + +| Name | Type | +| :------ | :------ | +| `updateNotification` | [`UpdateNotification`](UpdateNotification.md) | + +##### Returns + +`void` + +#### Defined in + +[db/DBAdapter.ts:64](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/db/DBAdapter.ts#L64) diff --git a/docs/docs/common-sdk/interfaces/DBGetUtils.md b/docs/docs/common-sdk/interfaces/DBGetUtils.md new file mode 100644 index 00000000..55254d2a --- /dev/null +++ b/docs/docs/common-sdk/interfaces/DBGetUtils.md @@ -0,0 +1,96 @@ +--- +id: "DBGetUtils" +title: "Interface: DBGetUtils" +sidebar_label: "DBGetUtils" +sidebar_position: 0 +custom_edit_url: null +--- + +## Hierarchy + +- **`DBGetUtils`** + + ↳ [`LockContext`](LockContext.md) + + ↳ [`DBAdapter`](DBAdapter.md) + +## Methods + +### get + +▸ **get**<`T`\>(`sql`, `parameters?`): `Promise`<`T`\> + +#### Type parameters + +| Name | +| :------ | +| `T` | + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `sql` | `string` | +| `parameters?` | `any`[] | + +#### Returns + +`Promise`<`T`\> + +#### Defined in + +[db/DBAdapter.ts:37](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/db/DBAdapter.ts#L37) + +___ + +### getAll + +▸ **getAll**<`T`\>(`sql`, `parameters?`): `Promise`<`T`[]\> + +#### Type parameters + +| Name | +| :------ | +| `T` | + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `sql` | `string` | +| `parameters?` | `any`[] | + +#### Returns + +`Promise`<`T`[]\> + +#### Defined in + +[db/DBAdapter.ts:35](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/db/DBAdapter.ts#L35) + +___ + +### getOptional + +▸ **getOptional**<`T`\>(`sql`, `parameters?`): `Promise`<`T`\> + +#### Type parameters + +| Name | +| :------ | +| `T` | + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `sql` | `string` | +| `parameters?` | `any`[] | + +#### Returns + +`Promise`<`T`\> + +#### Defined in + +[db/DBAdapter.ts:36](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/db/DBAdapter.ts#L36) diff --git a/docs/docs/common-sdk/interfaces/DBLockOptions.md b/docs/docs/common-sdk/interfaces/DBLockOptions.md new file mode 100644 index 00000000..d570b640 --- /dev/null +++ b/docs/docs/common-sdk/interfaces/DBLockOptions.md @@ -0,0 +1,17 @@ +--- +id: "DBLockOptions" +title: "Interface: DBLockOptions" +sidebar_label: "DBLockOptions" +sidebar_position: 0 +custom_edit_url: null +--- + +## Properties + +### timeoutMs + +• `Optional` **timeoutMs**: `number` + +#### Defined in + +[db/DBAdapter.ts:68](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/db/DBAdapter.ts#L68) diff --git a/docs/docs/common-sdk/interfaces/IndexColumnOptions.md b/docs/docs/common-sdk/interfaces/IndexColumnOptions.md new file mode 100644 index 00000000..ec31bada --- /dev/null +++ b/docs/docs/common-sdk/interfaces/IndexColumnOptions.md @@ -0,0 +1,27 @@ +--- +id: "IndexColumnOptions" +title: "Interface: IndexColumnOptions" +sidebar_label: "IndexColumnOptions" +sidebar_position: 0 +custom_edit_url: null +--- + +## Properties + +### ascending + +• `Optional` **ascending**: `boolean` + +#### Defined in + +[db/schema/IndexedColumn.ts:6](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/db/schema/IndexedColumn.ts#L6) + +___ + +### name + +• **name**: `string` + +#### Defined in + +[db/schema/IndexedColumn.ts:5](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/db/schema/IndexedColumn.ts#L5) diff --git a/docs/docs/common-sdk/interfaces/IndexOptions.md b/docs/docs/common-sdk/interfaces/IndexOptions.md new file mode 100644 index 00000000..6d252901 --- /dev/null +++ b/docs/docs/common-sdk/interfaces/IndexOptions.md @@ -0,0 +1,27 @@ +--- +id: "IndexOptions" +title: "Interface: IndexOptions" +sidebar_label: "IndexOptions" +sidebar_position: 0 +custom_edit_url: null +--- + +## Properties + +### columns + +• `Optional` **columns**: [`IndexedColumn`](../classes/IndexedColumn.md)[] + +#### Defined in + +[db/schema/Index.ts:6](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/db/schema/Index.ts#L6) + +___ + +### name + +• **name**: `string` + +#### Defined in + +[db/schema/Index.ts:5](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/db/schema/Index.ts#L5) diff --git a/docs/docs/common-sdk/interfaces/LockContext.md b/docs/docs/common-sdk/interfaces/LockContext.md new file mode 100644 index 00000000..eb3caffa --- /dev/null +++ b/docs/docs/common-sdk/interfaces/LockContext.md @@ -0,0 +1,133 @@ +--- +id: "LockContext" +title: "Interface: LockContext" +sidebar_label: "LockContext" +sidebar_position: 0 +custom_edit_url: null +--- + +## Hierarchy + +- [`DBGetUtils`](DBGetUtils.md) + + ↳ **`LockContext`** + + ↳↳ [`Transaction`](Transaction.md) + +## Properties + +### execute + +• **execute**: (`query`: `string`, `params?`: `any`[]) => `Promise`<[`QueryResult`](QueryResult.md)\> + +#### Type declaration + +▸ (`query`, `params?`): `Promise`<[`QueryResult`](QueryResult.md)\> + +##### Parameters + +| Name | Type | +| :------ | :------ | +| `query` | `string` | +| `params?` | `any`[] | + +##### Returns + +`Promise`<[`QueryResult`](QueryResult.md)\> + +#### Defined in + +[db/DBAdapter.ts:41](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/db/DBAdapter.ts#L41) + +## Methods + +### get + +▸ **get**<`T`\>(`sql`, `parameters?`): `Promise`<`T`\> + +#### Type parameters + +| Name | +| :------ | +| `T` | + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `sql` | `string` | +| `parameters?` | `any`[] | + +#### Returns + +`Promise`<`T`\> + +#### Inherited from + +[DBGetUtils](DBGetUtils.md).[get](DBGetUtils.md#get) + +#### Defined in + +[db/DBAdapter.ts:37](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/db/DBAdapter.ts#L37) + +___ + +### getAll + +▸ **getAll**<`T`\>(`sql`, `parameters?`): `Promise`<`T`[]\> + +#### Type parameters + +| Name | +| :------ | +| `T` | + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `sql` | `string` | +| `parameters?` | `any`[] | + +#### Returns + +`Promise`<`T`[]\> + +#### Inherited from + +[DBGetUtils](DBGetUtils.md).[getAll](DBGetUtils.md#getall) + +#### Defined in + +[db/DBAdapter.ts:35](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/db/DBAdapter.ts#L35) + +___ + +### getOptional + +▸ **getOptional**<`T`\>(`sql`, `parameters?`): `Promise`<`T`\> + +#### Type parameters + +| Name | +| :------ | +| `T` | + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `sql` | `string` | +| `parameters?` | `any`[] | + +#### Returns + +`Promise`<`T`\> + +#### Inherited from + +[DBGetUtils](DBGetUtils.md).[getOptional](DBGetUtils.md#getoptional) + +#### Defined in + +[db/DBAdapter.ts:36](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/db/DBAdapter.ts#L36) diff --git a/docs/docs/common-sdk/interfaces/LockOptions.md b/docs/docs/common-sdk/interfaces/LockOptions.md new file mode 100644 index 00000000..dc220ff1 --- /dev/null +++ b/docs/docs/common-sdk/interfaces/LockOptions.md @@ -0,0 +1,53 @@ +--- +id: "LockOptions" +title: "Interface: LockOptions" +sidebar_label: "LockOptions" +sidebar_position: 0 +custom_edit_url: null +--- + +Abstract Lock to be implemented by various JS environments + +## Type parameters + +| Name | +| :------ | +| `T` | + +## Properties + +### callback + +• **callback**: () => `Promise`<`T`\> + +#### Type declaration + +▸ (): `Promise`<`T`\> + +##### Returns + +`Promise`<`T`\> + +#### Defined in + +[client/sync/stream/AbstractStreamingSyncImplementation.ts:29](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/stream/AbstractStreamingSyncImplementation.ts#L29) + +___ + +### signal + +• `Optional` **signal**: `AbortSignal` + +#### Defined in + +[client/sync/stream/AbstractStreamingSyncImplementation.ts:31](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/stream/AbstractStreamingSyncImplementation.ts#L31) + +___ + +### type + +• **type**: [`LockType`](../enums/LockType.md) + +#### Defined in + +[client/sync/stream/AbstractStreamingSyncImplementation.ts:30](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/stream/AbstractStreamingSyncImplementation.ts#L30) diff --git a/docs/docs/common-sdk/interfaces/PowerSyncBackendConnector.md b/docs/docs/common-sdk/interfaces/PowerSyncBackendConnector.md new file mode 100644 index 00000000..4e4c57f1 --- /dev/null +++ b/docs/docs/common-sdk/interfaces/PowerSyncBackendConnector.md @@ -0,0 +1,65 @@ +--- +id: "PowerSyncBackendConnector" +title: "Interface: PowerSyncBackendConnector" +sidebar_label: "PowerSyncBackendConnector" +sidebar_position: 0 +custom_edit_url: null +--- + +## Properties + +### fetchCredentials + +• **fetchCredentials**: () => `Promise`<[`PowerSyncCredentials`](PowerSyncCredentials.md)\> + +#### Type declaration + +▸ (): `Promise`<[`PowerSyncCredentials`](PowerSyncCredentials.md)\> + +Get credentials for PowerSync. + +This should always fetch a fresh set of credentials - don't use cached +values. + +Return null if the user is not signed in. Throw an error if credentials +cannot be fetched due to a network error or other temporary error. + +This token is kept for the duration of a sync connection. + +##### Returns + +`Promise`<[`PowerSyncCredentials`](PowerSyncCredentials.md)\> + +#### Defined in + +[client/connection/PowerSyncBackendConnector.ts:15](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/connection/PowerSyncBackendConnector.ts#L15) + +___ + +### uploadData + +• **uploadData**: (`database`: [`AbstractPowerSyncDatabase`](../classes/AbstractPowerSyncDatabase.md)) => `Promise`<`void`\> + +#### Type declaration + +▸ (`database`): `Promise`<`void`\> + +Upload local changes to the app backend. + +Use [PowerSyncDatabase.getCrudBatch] to get a batch of changes to upload. See [DevConnector] for an example implementation. + +Any thrown errors will result in a retry after the configured wait period (default: 5 seconds). + +##### Parameters + +| Name | Type | +| :------ | :------ | +| `database` | [`AbstractPowerSyncDatabase`](../classes/AbstractPowerSyncDatabase.md) | + +##### Returns + +`Promise`<`void`\> + +#### Defined in + +[client/connection/PowerSyncBackendConnector.ts:23](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/connection/PowerSyncBackendConnector.ts#L23) diff --git a/docs/docs/common-sdk/interfaces/PowerSyncCredentials.md b/docs/docs/common-sdk/interfaces/PowerSyncCredentials.md new file mode 100644 index 00000000..f3b73f98 --- /dev/null +++ b/docs/docs/common-sdk/interfaces/PowerSyncCredentials.md @@ -0,0 +1,37 @@ +--- +id: "PowerSyncCredentials" +title: "Interface: PowerSyncCredentials" +sidebar_label: "PowerSyncCredentials" +sidebar_position: 0 +custom_edit_url: null +--- + +## Properties + +### endpoint + +• **endpoint**: `string` + +#### Defined in + +[client/connection/PowerSyncCredentials.ts:2](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/connection/PowerSyncCredentials.ts#L2) + +___ + +### expiresAt + +• `Optional` **expiresAt**: `Date` + +#### Defined in + +[client/connection/PowerSyncCredentials.ts:4](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/connection/PowerSyncCredentials.ts#L4) + +___ + +### token + +• **token**: `string` + +#### Defined in + +[client/connection/PowerSyncCredentials.ts:3](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/connection/PowerSyncCredentials.ts#L3) diff --git a/docs/docs/common-sdk/interfaces/PowerSyncDBListener.md b/docs/docs/common-sdk/interfaces/PowerSyncDBListener.md new file mode 100644 index 00000000..fe475176 --- /dev/null +++ b/docs/docs/common-sdk/interfaces/PowerSyncDBListener.md @@ -0,0 +1,59 @@ +--- +id: "PowerSyncDBListener" +title: "Interface: PowerSyncDBListener" +sidebar_label: "PowerSyncDBListener" +sidebar_position: 0 +custom_edit_url: null +--- + +## Hierarchy + +- [`StreamingSyncImplementationListener`](StreamingSyncImplementationListener.md) + + ↳ **`PowerSyncDBListener`** + +## Properties + +### initialized + +• **initialized**: () => `void` + +#### Type declaration + +▸ (): `void` + +##### Returns + +`void` + +#### Defined in + +[client/AbstractPowerSyncDatabase.ts:39](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/AbstractPowerSyncDatabase.ts#L39) + +___ + +### statusChanged + +• `Optional` **statusChanged**: (`status`: [`SyncStatus`](../classes/SyncStatus.md)) => `void` + +#### Type declaration + +▸ (`status`): `void` + +##### Parameters + +| Name | Type | +| :------ | :------ | +| `status` | [`SyncStatus`](../classes/SyncStatus.md) | + +##### Returns + +`void` + +#### Inherited from + +[StreamingSyncImplementationListener](StreamingSyncImplementationListener.md).[statusChanged](StreamingSyncImplementationListener.md#statuschanged) + +#### Defined in + +[client/sync/stream/AbstractStreamingSyncImplementation.ts:43](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/stream/AbstractStreamingSyncImplementation.ts#L43) diff --git a/docs/docs/common-sdk/interfaces/PowerSyncDatabaseOptions.md b/docs/docs/common-sdk/interfaces/PowerSyncDatabaseOptions.md new file mode 100644 index 00000000..52c3c548 --- /dev/null +++ b/docs/docs/common-sdk/interfaces/PowerSyncDatabaseOptions.md @@ -0,0 +1,47 @@ +--- +id: "PowerSyncDatabaseOptions" +title: "Interface: PowerSyncDatabaseOptions" +sidebar_label: "PowerSyncDatabaseOptions" +sidebar_position: 0 +custom_edit_url: null +--- + +## Properties + +### database + +• **database**: [`DBAdapter`](DBAdapter.md) + +#### Defined in + +[client/AbstractPowerSyncDatabase.ts:23](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/AbstractPowerSyncDatabase.ts#L23) + +___ + +### logger + +• `Optional` **logger**: `ILogger` + +#### Defined in + +[client/AbstractPowerSyncDatabase.ts:25](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/AbstractPowerSyncDatabase.ts#L25) + +___ + +### retryDelay + +• `Optional` **retryDelay**: `number` + +#### Defined in + +[client/AbstractPowerSyncDatabase.ts:24](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/AbstractPowerSyncDatabase.ts#L24) + +___ + +### schema + +• **schema**: [`Schema`](../classes/Schema.md) + +#### Defined in + +[client/AbstractPowerSyncDatabase.ts:22](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/AbstractPowerSyncDatabase.ts#L22) diff --git a/docs/docs/common-sdk/interfaces/PowerSyncOpenFactoryOptions.md b/docs/docs/common-sdk/interfaces/PowerSyncOpenFactoryOptions.md new file mode 100644 index 00000000..5e2dc5eb --- /dev/null +++ b/docs/docs/common-sdk/interfaces/PowerSyncOpenFactoryOptions.md @@ -0,0 +1,41 @@ +--- +id: "PowerSyncOpenFactoryOptions" +title: "Interface: PowerSyncOpenFactoryOptions" +sidebar_label: "PowerSyncOpenFactoryOptions" +sidebar_position: 0 +custom_edit_url: null +--- + +## Properties + +### dbFilename + +• **dbFilename**: `string` + +Filename for the database. + +#### Defined in + +[client/AbstractPowerSyncOpenFactory.ts:10](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/AbstractPowerSyncOpenFactory.ts#L10) + +___ + +### dbLocation + +• `Optional` **dbLocation**: `string` + +Directory where the database file is located. + +#### Defined in + +[client/AbstractPowerSyncOpenFactory.ts:14](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/AbstractPowerSyncOpenFactory.ts#L14) + +___ + +### schema + +• **schema**: [`Schema`](../classes/Schema.md) + +#### Defined in + +[client/AbstractPowerSyncOpenFactory.ts:6](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/AbstractPowerSyncOpenFactory.ts#L6) diff --git a/docs/docs/common-sdk/interfaces/QueryResult.md b/docs/docs/common-sdk/interfaces/QueryResult.md new file mode 100644 index 00000000..0a9c3a80 --- /dev/null +++ b/docs/docs/common-sdk/interfaces/QueryResult.md @@ -0,0 +1,54 @@ +--- +id: "QueryResult" +title: "Interface: QueryResult" +sidebar_label: "QueryResult" +sidebar_position: 0 +custom_edit_url: null +--- + +Object returned by SQL Query executions { + insertId: Represent the auto-generated row id if applicable + rowsAffected: Number of affected rows if result of a update query + message: if status === 1, here you will find error description + rows: if status is undefined or 0 this object will contain the query results +} + + QueryResult + +## Properties + +### insertId + +• `Optional` **insertId**: `number` + +#### Defined in + +[db/DBAdapter.ts:19](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/db/DBAdapter.ts#L19) + +___ + +### rows + +• `Optional` **rows**: `Object` + +#### Type declaration + +| Name | Type | Description | +| :------ | :------ | :------ | +| `_array` | `any`[] | Raw array with all dataset | +| `item` | (`idx`: `number`) => `any` | A convenience function to acess the index based the row object | +| `length` | `number` | The length of the dataset | + +#### Defined in + +[db/DBAdapter.ts:21](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/db/DBAdapter.ts#L21) + +___ + +### rowsAffected + +• **rowsAffected**: `number` + +#### Defined in + +[db/DBAdapter.ts:20](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/db/DBAdapter.ts#L20) diff --git a/docs/docs/common-sdk/interfaces/SQLWatchOptions.md b/docs/docs/common-sdk/interfaces/SQLWatchOptions.md new file mode 100644 index 00000000..8dd0142e --- /dev/null +++ b/docs/docs/common-sdk/interfaces/SQLWatchOptions.md @@ -0,0 +1,37 @@ +--- +id: "SQLWatchOptions" +title: "Interface: SQLWatchOptions" +sidebar_label: "SQLWatchOptions" +sidebar_position: 0 +custom_edit_url: null +--- + +## Properties + +### signal + +• `Optional` **signal**: `AbortSignal` + +#### Defined in + +[client/AbstractPowerSyncDatabase.ts:29](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/AbstractPowerSyncDatabase.ts#L29) + +___ + +### tables + +• `Optional` **tables**: `string`[] + +#### Defined in + +[client/AbstractPowerSyncDatabase.ts:30](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/AbstractPowerSyncDatabase.ts#L30) + +___ + +### throttleMs + +• `Optional` **throttleMs**: `number` + +#### Defined in + +[client/AbstractPowerSyncDatabase.ts:31](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/AbstractPowerSyncDatabase.ts#L31) diff --git a/docs/docs/common-sdk/interfaces/StreamingSyncCheckpoint.md b/docs/docs/common-sdk/interfaces/StreamingSyncCheckpoint.md new file mode 100644 index 00000000..6d81eb7b --- /dev/null +++ b/docs/docs/common-sdk/interfaces/StreamingSyncCheckpoint.md @@ -0,0 +1,17 @@ +--- +id: "StreamingSyncCheckpoint" +title: "Interface: StreamingSyncCheckpoint" +sidebar_label: "StreamingSyncCheckpoint" +sidebar_position: 0 +custom_edit_url: null +--- + +## Properties + +### checkpoint + +• **checkpoint**: [`Checkpoint`](Checkpoint.md) + +#### Defined in + +[client/sync/stream/streaming-sync-types.ts:81](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/stream/streaming-sync-types.ts#L81) diff --git a/docs/docs/common-sdk/interfaces/StreamingSyncCheckpointComplete.md b/docs/docs/common-sdk/interfaces/StreamingSyncCheckpointComplete.md new file mode 100644 index 00000000..49f4d6a8 --- /dev/null +++ b/docs/docs/common-sdk/interfaces/StreamingSyncCheckpointComplete.md @@ -0,0 +1,23 @@ +--- +id: "StreamingSyncCheckpointComplete" +title: "Interface: StreamingSyncCheckpointComplete" +sidebar_label: "StreamingSyncCheckpointComplete" +sidebar_position: 0 +custom_edit_url: null +--- + +## Properties + +### checkpoint\_complete + +• **checkpoint\_complete**: `Object` + +#### Type declaration + +| Name | Type | +| :------ | :------ | +| `last_op_id` | `string` | + +#### Defined in + +[client/sync/stream/streaming-sync-types.ts:98](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/stream/streaming-sync-types.ts#L98) diff --git a/docs/docs/common-sdk/interfaces/StreamingSyncCheckpointDiff.md b/docs/docs/common-sdk/interfaces/StreamingSyncCheckpointDiff.md new file mode 100644 index 00000000..ae3a7fa6 --- /dev/null +++ b/docs/docs/common-sdk/interfaces/StreamingSyncCheckpointDiff.md @@ -0,0 +1,26 @@ +--- +id: "StreamingSyncCheckpointDiff" +title: "Interface: StreamingSyncCheckpointDiff" +sidebar_label: "StreamingSyncCheckpointDiff" +sidebar_position: 0 +custom_edit_url: null +--- + +## Properties + +### checkpoint\_diff + +• **checkpoint\_diff**: `Object` + +#### Type declaration + +| Name | Type | +| :------ | :------ | +| `last_op_id` | `string` | +| `removed_buckets` | `string`[] | +| `updated_buckets` | [`BucketChecksum`](BucketChecksum.md)[] | +| `write_checkpoint` | `string` | + +#### Defined in + +[client/sync/stream/streaming-sync-types.ts:85](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/stream/streaming-sync-types.ts#L85) diff --git a/docs/docs/common-sdk/interfaces/StreamingSyncDataJSON.md b/docs/docs/common-sdk/interfaces/StreamingSyncDataJSON.md new file mode 100644 index 00000000..b876246b --- /dev/null +++ b/docs/docs/common-sdk/interfaces/StreamingSyncDataJSON.md @@ -0,0 +1,17 @@ +--- +id: "StreamingSyncDataJSON" +title: "Interface: StreamingSyncDataJSON" +sidebar_label: "StreamingSyncDataJSON" +sidebar_position: 0 +custom_edit_url: null +--- + +## Properties + +### data + +• **data**: [`SyncDataBucketJSON`](../modules.md#syncdatabucketjson) + +#### Defined in + +[client/sync/stream/streaming-sync-types.ts:94](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/stream/streaming-sync-types.ts#L94) diff --git a/docs/docs/common-sdk/interfaces/StreamingSyncImplementationListener.md b/docs/docs/common-sdk/interfaces/StreamingSyncImplementationListener.md new file mode 100644 index 00000000..64beb199 --- /dev/null +++ b/docs/docs/common-sdk/interfaces/StreamingSyncImplementationListener.md @@ -0,0 +1,39 @@ +--- +id: "StreamingSyncImplementationListener" +title: "Interface: StreamingSyncImplementationListener" +sidebar_label: "StreamingSyncImplementationListener" +sidebar_position: 0 +custom_edit_url: null +--- + +## Hierarchy + +- [`BaseListener`](../modules.md#baselistener) + + ↳ **`StreamingSyncImplementationListener`** + + ↳↳ [`PowerSyncDBListener`](PowerSyncDBListener.md) + +## Properties + +### statusChanged + +• `Optional` **statusChanged**: (`status`: [`SyncStatus`](../classes/SyncStatus.md)) => `void` + +#### Type declaration + +▸ (`status`): `void` + +##### Parameters + +| Name | Type | +| :------ | :------ | +| `status` | [`SyncStatus`](../classes/SyncStatus.md) | + +##### Returns + +`void` + +#### Defined in + +[client/sync/stream/AbstractStreamingSyncImplementation.ts:43](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/stream/AbstractStreamingSyncImplementation.ts#L43) diff --git a/docs/docs/common-sdk/interfaces/StreamingSyncKeepalive.md b/docs/docs/common-sdk/interfaces/StreamingSyncKeepalive.md new file mode 100644 index 00000000..2466d25b --- /dev/null +++ b/docs/docs/common-sdk/interfaces/StreamingSyncKeepalive.md @@ -0,0 +1,19 @@ +--- +id: "StreamingSyncKeepalive" +title: "Interface: StreamingSyncKeepalive" +sidebar_label: "StreamingSyncKeepalive" +sidebar_position: 0 +custom_edit_url: null +--- + +## Properties + +### token\_expires\_in + +• **token\_expires\_in**: `number` + +If specified, token expires in this many seconds. + +#### Defined in + +[client/sync/stream/streaming-sync-types.ts:105](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/stream/streaming-sync-types.ts#L105) diff --git a/docs/docs/common-sdk/interfaces/StreamingSyncRequest.md b/docs/docs/common-sdk/interfaces/StreamingSyncRequest.md new file mode 100644 index 00000000..e726e537 --- /dev/null +++ b/docs/docs/common-sdk/interfaces/StreamingSyncRequest.md @@ -0,0 +1,55 @@ +--- +id: "StreamingSyncRequest" +title: "Interface: StreamingSyncRequest" +sidebar_label: "StreamingSyncRequest" +sidebar_position: 0 +custom_edit_url: null +--- + +## Properties + +### buckets + +• `Optional` **buckets**: [`BucketRequest`](BucketRequest.md)[] + +Existing bucket states. + +#### Defined in + +[client/sync/stream/streaming-sync-types.ts:62](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/stream/streaming-sync-types.ts#L62) + +___ + +### include\_checksum + +• **include\_checksum**: `boolean` + +Whether or not to compute a checksum for each checkpoint + +#### Defined in + +[client/sync/stream/streaming-sync-types.ts:72](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/stream/streaming-sync-types.ts#L72) + +___ + +### only + +• `Optional` **only**: `string`[] + +If specified, limit the response to only include these buckets. + +#### Defined in + +[client/sync/stream/streaming-sync-types.ts:67](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/stream/streaming-sync-types.ts#L67) + +___ + +### raw\_data + +• **raw\_data**: `boolean` + +Changes the response to stringified data in each OplogEntry + +#### Defined in + +[client/sync/stream/streaming-sync-types.ts:77](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/stream/streaming-sync-types.ts#L77) diff --git a/docs/docs/common-sdk/interfaces/SyncLocalDatabaseResult.md b/docs/docs/common-sdk/interfaces/SyncLocalDatabaseResult.md new file mode 100644 index 00000000..71be9b29 --- /dev/null +++ b/docs/docs/common-sdk/interfaces/SyncLocalDatabaseResult.md @@ -0,0 +1,37 @@ +--- +id: "SyncLocalDatabaseResult" +title: "Interface: SyncLocalDatabaseResult" +sidebar_label: "SyncLocalDatabaseResult" +sidebar_position: 0 +custom_edit_url: null +--- + +## Properties + +### checkpointValid + +• **checkpointValid**: `boolean` + +#### Defined in + +[client/sync/bucket/BucketStorageAdapter.ts:23](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/BucketStorageAdapter.ts#L23) + +___ + +### failures + +• `Optional` **failures**: `string`[] + +#### Defined in + +[client/sync/bucket/BucketStorageAdapter.ts:24](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/BucketStorageAdapter.ts#L24) + +___ + +### ready + +• **ready**: `boolean` + +#### Defined in + +[client/sync/bucket/BucketStorageAdapter.ts:22](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/BucketStorageAdapter.ts#L22) diff --git a/docs/docs/common-sdk/interfaces/SyncNewCheckpointRequest.md b/docs/docs/common-sdk/interfaces/SyncNewCheckpointRequest.md new file mode 100644 index 00000000..aefcae45 --- /dev/null +++ b/docs/docs/common-sdk/interfaces/SyncNewCheckpointRequest.md @@ -0,0 +1,46 @@ +--- +id: "SyncNewCheckpointRequest" +title: "Interface: SyncNewCheckpointRequest" +sidebar_label: "SyncNewCheckpointRequest" +sidebar_position: 0 +custom_edit_url: null +--- + +## Properties + +### buckets + +• `Optional` **buckets**: [`BucketRequest`](BucketRequest.md)[] + +Existing bucket states. Used if include_data is specified. + +#### Defined in + +[client/sync/stream/streaming-sync-types.ts:23](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/stream/streaming-sync-types.ts#L23) + +___ + +### limit + +• `Optional` **limit**: `number` + +#### Defined in + +[client/sync/stream/streaming-sync-types.ts:37](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/stream/streaming-sync-types.ts#L37) + +___ + +### request\_checkpoint + +• **request\_checkpoint**: `Object` + +#### Type declaration + +| Name | Type | Description | +| :------ | :------ | :------ | +| `include_checksum` | `boolean` | Whether or not to compute a checksum. | +| `include_data` | `boolean` | Whether or not to include an initial data request. | + +#### Defined in + +[client/sync/stream/streaming-sync-types.ts:25](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/stream/streaming-sync-types.ts#L25) diff --git a/docs/docs/common-sdk/interfaces/SyncResponse.md b/docs/docs/common-sdk/interfaces/SyncResponse.md new file mode 100644 index 00000000..12d5d935 --- /dev/null +++ b/docs/docs/common-sdk/interfaces/SyncResponse.md @@ -0,0 +1,51 @@ +--- +id: "SyncResponse" +title: "Interface: SyncResponse" +sidebar_label: "SyncResponse" +sidebar_position: 0 +custom_edit_url: null +--- + +## Properties + +### checkpoint + +• `Optional` **checkpoint**: [`Checkpoint`](Checkpoint.md) + +#### Defined in + +[client/sync/stream/streaming-sync-types.ts:55](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/stream/streaming-sync-types.ts#L55) + +___ + +### checkpoint\_token + +• `Optional` **checkpoint\_token**: `string` + +#### Defined in + +[client/sync/stream/streaming-sync-types.ts:53](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/stream/streaming-sync-types.ts#L53) + +___ + +### data + +• `Optional` **data**: [`SyncDataBucketJSON`](../modules.md#syncdatabucketjson)[] + +Data for the buckets returned. May not have an an entry for each bucket in the request. + +#### Defined in + +[client/sync/stream/streaming-sync-types.ts:46](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/stream/streaming-sync-types.ts#L46) + +___ + +### has\_more + +• **has\_more**: `boolean` + +True if the response limit has been reached, and another request must be made. + +#### Defined in + +[client/sync/stream/streaming-sync-types.ts:51](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/stream/streaming-sync-types.ts#L51) diff --git a/docs/docs/common-sdk/interfaces/TableOptions.md b/docs/docs/common-sdk/interfaces/TableOptions.md new file mode 100644 index 00000000..baa69281 --- /dev/null +++ b/docs/docs/common-sdk/interfaces/TableOptions.md @@ -0,0 +1,57 @@ +--- +id: "TableOptions" +title: "Interface: TableOptions" +sidebar_label: "TableOptions" +sidebar_position: 0 +custom_edit_url: null +--- + +## Properties + +### columns + +• **columns**: [`Column`](../classes/Column.md)[] + +#### Defined in + +[db/schema/Table.ts:6](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/db/schema/Table.ts#L6) + +___ + +### indexes + +• `Optional` **indexes**: [`Index`](../classes/Index.md)[] + +#### Defined in + +[db/schema/Table.ts:7](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/db/schema/Table.ts#L7) + +___ + +### insertOnly + +• `Optional` **insertOnly**: `boolean` + +#### Defined in + +[db/schema/Table.ts:9](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/db/schema/Table.ts#L9) + +___ + +### localOnly + +• `Optional` **localOnly**: `boolean` + +#### Defined in + +[db/schema/Table.ts:8](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/db/schema/Table.ts#L8) + +___ + +### name + +• **name**: `string` + +#### Defined in + +[db/schema/Table.ts:5](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/db/schema/Table.ts#L5) diff --git a/docs/docs/common-sdk/interfaces/Transaction.md b/docs/docs/common-sdk/interfaces/Transaction.md new file mode 100644 index 00000000..0a695d83 --- /dev/null +++ b/docs/docs/common-sdk/interfaces/Transaction.md @@ -0,0 +1,171 @@ +--- +id: "Transaction" +title: "Interface: Transaction" +sidebar_label: "Transaction" +sidebar_position: 0 +custom_edit_url: null +--- + +## Hierarchy + +- [`LockContext`](LockContext.md) + + ↳ **`Transaction`** + +## Properties + +### commit + +• **commit**: () => `Promise`<[`QueryResult`](QueryResult.md)\> + +#### Type declaration + +▸ (): `Promise`<[`QueryResult`](QueryResult.md)\> + +##### Returns + +`Promise`<[`QueryResult`](QueryResult.md)\> + +#### Defined in + +[db/DBAdapter.ts:45](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/db/DBAdapter.ts#L45) + +___ + +### execute + +• **execute**: (`query`: `string`, `params?`: `any`[]) => `Promise`<[`QueryResult`](QueryResult.md)\> + +#### Type declaration + +▸ (`query`, `params?`): `Promise`<[`QueryResult`](QueryResult.md)\> + +##### Parameters + +| Name | Type | +| :------ | :------ | +| `query` | `string` | +| `params?` | `any`[] | + +##### Returns + +`Promise`<[`QueryResult`](QueryResult.md)\> + +#### Inherited from + +[LockContext](LockContext.md).[execute](LockContext.md#execute) + +#### Defined in + +[db/DBAdapter.ts:41](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/db/DBAdapter.ts#L41) + +___ + +### rollback + +• **rollback**: () => `Promise`<[`QueryResult`](QueryResult.md)\> + +#### Type declaration + +▸ (): `Promise`<[`QueryResult`](QueryResult.md)\> + +##### Returns + +`Promise`<[`QueryResult`](QueryResult.md)\> + +#### Defined in + +[db/DBAdapter.ts:46](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/db/DBAdapter.ts#L46) + +## Methods + +### get + +▸ **get**<`T`\>(`sql`, `parameters?`): `Promise`<`T`\> + +#### Type parameters + +| Name | +| :------ | +| `T` | + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `sql` | `string` | +| `parameters?` | `any`[] | + +#### Returns + +`Promise`<`T`\> + +#### Inherited from + +[LockContext](LockContext.md).[get](LockContext.md#get) + +#### Defined in + +[db/DBAdapter.ts:37](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/db/DBAdapter.ts#L37) + +___ + +### getAll + +▸ **getAll**<`T`\>(`sql`, `parameters?`): `Promise`<`T`[]\> + +#### Type parameters + +| Name | +| :------ | +| `T` | + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `sql` | `string` | +| `parameters?` | `any`[] | + +#### Returns + +`Promise`<`T`[]\> + +#### Inherited from + +[LockContext](LockContext.md).[getAll](LockContext.md#getall) + +#### Defined in + +[db/DBAdapter.ts:35](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/db/DBAdapter.ts#L35) + +___ + +### getOptional + +▸ **getOptional**<`T`\>(`sql`, `parameters?`): `Promise`<`T`\> + +#### Type parameters + +| Name | +| :------ | +| `T` | + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `sql` | `string` | +| `parameters?` | `any`[] | + +#### Returns + +`Promise`<`T`\> + +#### Inherited from + +[LockContext](LockContext.md).[getOptional](LockContext.md#getoptional) + +#### Defined in + +[db/DBAdapter.ts:36](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/db/DBAdapter.ts#L36) diff --git a/docs/docs/common-sdk/interfaces/UpdateNotification.md b/docs/docs/common-sdk/interfaces/UpdateNotification.md new file mode 100644 index 00000000..cc0291f4 --- /dev/null +++ b/docs/docs/common-sdk/interfaces/UpdateNotification.md @@ -0,0 +1,37 @@ +--- +id: "UpdateNotification" +title: "Interface: UpdateNotification" +sidebar_label: "UpdateNotification" +sidebar_position: 0 +custom_edit_url: null +--- + +## Properties + +### opType + +• **opType**: [`RowUpdateType`](../enums/RowUpdateType.md) + +#### Defined in + +[db/DBAdapter.ts:58](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/db/DBAdapter.ts#L58) + +___ + +### rowId + +• **rowId**: `number` + +#### Defined in + +[db/DBAdapter.ts:60](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/db/DBAdapter.ts#L60) + +___ + +### table + +• **table**: `string` + +#### Defined in + +[db/DBAdapter.ts:59](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/db/DBAdapter.ts#L59) diff --git a/docs/docs/common-sdk/interfaces/WatchOnChangeEvent.md b/docs/docs/common-sdk/interfaces/WatchOnChangeEvent.md new file mode 100644 index 00000000..525234e9 --- /dev/null +++ b/docs/docs/common-sdk/interfaces/WatchOnChangeEvent.md @@ -0,0 +1,17 @@ +--- +id: "WatchOnChangeEvent" +title: "Interface: WatchOnChangeEvent" +sidebar_label: "WatchOnChangeEvent" +sidebar_position: 0 +custom_edit_url: null +--- + +## Properties + +### changedTables + +• **changedTables**: `string`[] + +#### Defined in + +[client/AbstractPowerSyncDatabase.ts:35](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/AbstractPowerSyncDatabase.ts#L35) diff --git a/docs/docs/common-sdk/interfaces/_category_.yml b/docs/docs/common-sdk/interfaces/_category_.yml new file mode 100644 index 00000000..43bec88c --- /dev/null +++ b/docs/docs/common-sdk/interfaces/_category_.yml @@ -0,0 +1,2 @@ +label: "Interfaces" +position: 4 \ No newline at end of file diff --git a/docs/docs/common-sdk/modules.md b/docs/docs/common-sdk/modules.md new file mode 100644 index 00000000..3e7d6d56 --- /dev/null +++ b/docs/docs/common-sdk/modules.md @@ -0,0 +1,523 @@ +--- +id: "modules" +title: "@journeyapps/powersync-sdk-common" +sidebar_label: "Exports" +sidebar_position: 0.5 +custom_edit_url: null +--- + +## Enumerations + +- [ColumnType](enums/ColumnType.md) +- [LockType](enums/LockType.md) +- [OpTypeEnum](enums/OpTypeEnum.md) +- [RowUpdateType](enums/RowUpdateType.md) +- [UpdateType](enums/UpdateType.md) + +## Classes + +- [AbstractPowerSyncDatabase](classes/AbstractPowerSyncDatabase.md) +- [AbstractPowerSyncDatabaseOpenFactory](classes/AbstractPowerSyncDatabaseOpenFactory.md) +- [AbstractRemote](classes/AbstractRemote.md) +- [AbstractStreamingSyncImplementation](classes/AbstractStreamingSyncImplementation.md) +- [BaseObserver](classes/BaseObserver.md) +- [Column](classes/Column.md) +- [CrudBatch](classes/CrudBatch.md) +- [CrudEntry](classes/CrudEntry.md) +- [CrudTransaction](classes/CrudTransaction.md) +- [Index](classes/Index.md) +- [IndexedColumn](classes/IndexedColumn.md) +- [OpType](classes/OpType.md) +- [Schema](classes/Schema.md) +- [SqliteBucketStorage](classes/SqliteBucketStorage.md) +- [SyncDataBatch](classes/SyncDataBatch.md) +- [SyncDataBucket](classes/SyncDataBucket.md) +- [SyncStatus](classes/SyncStatus.md) +- [Table](classes/Table.md) +- [UploadQueueStats](classes/UploadQueueStats.md) + +## Interfaces + +- [AbstractStreamingSyncImplementationOptions](interfaces/AbstractStreamingSyncImplementationOptions.md) +- [BaseObserverInterface](interfaces/BaseObserverInterface.md) +- [BucketChecksum](interfaces/BucketChecksum.md) +- [BucketRequest](interfaces/BucketRequest.md) +- [BucketState](interfaces/BucketState.md) +- [BucketStorageAdapter](interfaces/BucketStorageAdapter.md) +- [Checkpoint](interfaces/Checkpoint.md) +- [ChecksumCache](interfaces/ChecksumCache.md) +- [ColumnOptions](interfaces/ColumnOptions.md) +- [ContinueCheckpointRequest](interfaces/ContinueCheckpointRequest.md) +- [CrudRequest](interfaces/CrudRequest.md) +- [CrudResponse](interfaces/CrudResponse.md) +- [DBAdapter](interfaces/DBAdapter.md) +- [DBAdapterListener](interfaces/DBAdapterListener.md) +- [DBGetUtils](interfaces/DBGetUtils.md) +- [DBLockOptions](interfaces/DBLockOptions.md) +- [IndexColumnOptions](interfaces/IndexColumnOptions.md) +- [IndexOptions](interfaces/IndexOptions.md) +- [LockContext](interfaces/LockContext.md) +- [LockOptions](interfaces/LockOptions.md) +- [PowerSyncBackendConnector](interfaces/PowerSyncBackendConnector.md) +- [PowerSyncCredentials](interfaces/PowerSyncCredentials.md) +- [PowerSyncDBListener](interfaces/PowerSyncDBListener.md) +- [PowerSyncDatabaseOptions](interfaces/PowerSyncDatabaseOptions.md) +- [PowerSyncOpenFactoryOptions](interfaces/PowerSyncOpenFactoryOptions.md) +- [QueryResult](interfaces/QueryResult.md) +- [SQLWatchOptions](interfaces/SQLWatchOptions.md) +- [StreamingSyncCheckpoint](interfaces/StreamingSyncCheckpoint.md) +- [StreamingSyncCheckpointComplete](interfaces/StreamingSyncCheckpointComplete.md) +- [StreamingSyncCheckpointDiff](interfaces/StreamingSyncCheckpointDiff.md) +- [StreamingSyncDataJSON](interfaces/StreamingSyncDataJSON.md) +- [StreamingSyncImplementationListener](interfaces/StreamingSyncImplementationListener.md) +- [StreamingSyncKeepalive](interfaces/StreamingSyncKeepalive.md) +- [StreamingSyncRequest](interfaces/StreamingSyncRequest.md) +- [SyncLocalDatabaseResult](interfaces/SyncLocalDatabaseResult.md) +- [SyncNewCheckpointRequest](interfaces/SyncNewCheckpointRequest.md) +- [SyncResponse](interfaces/SyncResponse.md) +- [TableOptions](interfaces/TableOptions.md) +- [Transaction](interfaces/Transaction.md) +- [UpdateNotification](interfaces/UpdateNotification.md) +- [WatchOnChangeEvent](interfaces/WatchOnChangeEvent.md) + +## Type Aliases + +### BaseListener + +Ƭ **BaseListener**: `Object` + +#### Index signature + +▪ [key: `string`]: (...`event`: `any`) => `any` + +#### Defined in + +[utils/BaseObserver.ts:7](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/utils/BaseObserver.ts#L7) + +___ + +### CrudEntryDataJSON + +Ƭ **CrudEntryDataJSON**: `Object` + +#### Type declaration + +| Name | Type | +| :------ | :------ | +| `data` | `Record`<`string`, `any`\> | +| `id` | `string` | +| `op` | [`UpdateType`](enums/UpdateType.md) | +| `type` | `string` | + +#### Defined in + +[client/sync/bucket/CrudEntry.ts:22](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/CrudEntry.ts#L22) + +___ + +### CrudEntryJSON + +Ƭ **CrudEntryJSON**: `Object` + +#### Type declaration + +| Name | Type | +| :------ | :------ | +| `data` | `string` | +| `id` | `string` | +| `tx_id?` | `number` | + +#### Defined in + +[client/sync/bucket/CrudEntry.ts:16](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/CrudEntry.ts#L16) + +___ + +### CrudEntryOutputJSON + +Ƭ **CrudEntryOutputJSON**: `Object` + +The output JSOn seems to be a third type of JSON, not the same as the input JSON. + +#### Type declaration + +| Name | Type | +| :------ | :------ | +| `data` | `Record`<`string`, `any`\> | +| `id` | `string` | +| `op` | [`UpdateType`](enums/UpdateType.md) | +| `op_id` | `number` | +| `tx_id?` | `number` | +| `type` | `string` | + +#### Defined in + +[client/sync/bucket/CrudEntry.ts:32](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/CrudEntry.ts#L32) + +___ + +### OpId + +Ƭ **OpId**: `string` + +64-bit unsigned integer stored as a string in base-10. + +Not sortable as a string. + +#### Defined in + +[client/sync/bucket/CrudEntry.ts:8](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/CrudEntry.ts#L8) + +___ + +### OpTypeJSON + +Ƭ **OpTypeJSON**: `string` + +#### Defined in + +[client/sync/bucket/OpType.ts:8](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/OpType.ts#L8) + +___ + +### RemoteConnector + +Ƭ **RemoteConnector**: `Object` + +#### Type declaration + +| Name | Type | +| :------ | :------ | +| `fetchCredentials` | () => `Promise`<[`PowerSyncCredentials`](interfaces/PowerSyncCredentials.md)\> | + +#### Defined in + +[client/sync/stream/AbstractRemote.ts:4](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/stream/AbstractRemote.ts#L4) + +___ + +### StreamingSyncLine + +Ƭ **StreamingSyncLine**: [`StreamingSyncDataJSON`](interfaces/StreamingSyncDataJSON.md) \| [`StreamingSyncCheckpoint`](interfaces/StreamingSyncCheckpoint.md) \| [`StreamingSyncCheckpointDiff`](interfaces/StreamingSyncCheckpointDiff.md) \| [`StreamingSyncCheckpointComplete`](interfaces/StreamingSyncCheckpointComplete.md) \| [`StreamingSyncKeepalive`](interfaces/StreamingSyncKeepalive.md) + +#### Defined in + +[client/sync/stream/streaming-sync-types.ts:108](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/stream/streaming-sync-types.ts#L108) + +___ + +### SyncDataBucketJSON + +Ƭ **SyncDataBucketJSON**: `Object` + +#### Type declaration + +| Name | Type | +| :------ | :------ | +| `after?` | `string` | +| `bucket` | `string` | +| `data` | `OplogEntryJSON`[] | +| `has_more?` | `boolean` | +| `next_after?` | `string` | + +#### Defined in + +[client/sync/bucket/SyncDataBucket.ts:4](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/SyncDataBucket.ts#L4) + +___ + +### SyncRequest + +Ƭ **SyncRequest**: [`ContinueCheckpointRequest`](interfaces/ContinueCheckpointRequest.md) \| [`SyncNewCheckpointRequest`](interfaces/SyncNewCheckpointRequest.md) + +#### Defined in + +[client/sync/stream/streaming-sync-types.ts:40](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/stream/streaming-sync-types.ts#L40) + +## Variables + +### DEFAULT\_INDEX\_COLUMN\_OPTIONS + +• `Const` **DEFAULT\_INDEX\_COLUMN\_OPTIONS**: `Partial`<[`IndexColumnOptions`](interfaces/IndexColumnOptions.md)\> + +#### Defined in + +[db/schema/IndexedColumn.ts:9](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/db/schema/IndexedColumn.ts#L9) + +___ + +### DEFAULT\_INDEX\_OPTIONS + +• `Const` **DEFAULT\_INDEX\_OPTIONS**: `Partial`<[`IndexOptions`](interfaces/IndexOptions.md)\> + +#### Defined in + +[db/schema/Index.ts:9](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/db/schema/Index.ts#L9) + +___ + +### DEFAULT\_LOCK\_TIMEOUT\_MS + +• `Const` **DEFAULT\_LOCK\_TIMEOUT\_MS**: ``120000`` + +Requesting nested or recursive locks can block the application in some circumstances. +This default lock timeout will act as a failsafe to throw an error if a lock cannot +be obtained. + +#### Defined in + +[client/AbstractPowerSyncDatabase.ts:56](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/AbstractPowerSyncDatabase.ts#L56) + +___ + +### DEFAULT\_POWERSYNC\_DB\_OPTIONS + +• `Const` **DEFAULT\_POWERSYNC\_DB\_OPTIONS**: `Object` + +#### Type declaration + +| Name | Type | +| :------ | :------ | +| `logger` | `ILogger` | +| `retryDelay` | `number` | + +#### Defined in + +[client/AbstractPowerSyncDatabase.ts:46](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/AbstractPowerSyncDatabase.ts#L46) + +___ + +### DEFAULT\_REMOTE\_LOGGER + +• `Const` **DEFAULT\_REMOTE\_LOGGER**: `ILogger` + +#### Defined in + +[client/sync/stream/AbstractRemote.ts:11](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/stream/AbstractRemote.ts#L11) + +___ + +### DEFAULT\_STREAMING\_SYNC\_OPTIONS + +• `Const` **DEFAULT\_STREAMING\_SYNC\_OPTIONS**: `Object` + +#### Type declaration + +| Name | Type | +| :------ | :------ | +| `logger` | `ILogger` | +| `retryDelayMs` | `number` | + +#### Defined in + +[client/sync/stream/AbstractStreamingSyncImplementation.ts:46](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/stream/AbstractStreamingSyncImplementation.ts#L46) + +___ + +### DEFAULT\_TABLE\_OPTIONS + +• `Const` **DEFAULT\_TABLE\_OPTIONS**: `Partial`<[`TableOptions`](interfaces/TableOptions.md)\> + +#### Defined in + +[db/schema/Table.ts:12](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/db/schema/Table.ts#L12) + +___ + +### DEFAULT\_WATCH\_THROTTLE\_MS + +• `Const` **DEFAULT\_WATCH\_THROTTLE\_MS**: ``30`` + +#### Defined in + +[client/AbstractPowerSyncDatabase.ts:44](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/AbstractPowerSyncDatabase.ts#L44) + +___ + +### MAX\_OP\_ID + +• `Const` **MAX\_OP\_ID**: ``"9223372036854775807"`` + +#### Defined in + +[client/sync/bucket/SyncDataBucket.ts:12](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/bucket/SyncDataBucket.ts#L12) + +## Functions + +### isContinueCheckpointRequest + +▸ **isContinueCheckpointRequest**(`request`): request is ContinueCheckpointRequest + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `request` | [`SyncRequest`](modules.md#syncrequest) | + +#### Returns + +request is ContinueCheckpointRequest + +#### Defined in + +[client/sync/stream/streaming-sync-types.ts:144](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/stream/streaming-sync-types.ts#L144) + +___ + +### isStreamingKeepalive + +▸ **isStreamingKeepalive**(`line`): line is StreamingSyncKeepalive + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `line` | [`StreamingSyncLine`](modules.md#streamingsyncline) | + +#### Returns + +line is StreamingSyncKeepalive + +#### Defined in + +[client/sync/stream/streaming-sync-types.ts:128](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/stream/streaming-sync-types.ts#L128) + +___ + +### isStreamingSyncCheckpoint + +▸ **isStreamingSyncCheckpoint**(`line`): line is StreamingSyncCheckpoint + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `line` | [`StreamingSyncLine`](modules.md#streamingsyncline) | + +#### Returns + +line is StreamingSyncCheckpoint + +#### Defined in + +[client/sync/stream/streaming-sync-types.ts:132](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/stream/streaming-sync-types.ts#L132) + +___ + +### isStreamingSyncCheckpointComplete + +▸ **isStreamingSyncCheckpointComplete**(`line`): line is StreamingSyncCheckpointComplete + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `line` | [`StreamingSyncLine`](modules.md#streamingsyncline) | + +#### Returns + +line is StreamingSyncCheckpointComplete + +#### Defined in + +[client/sync/stream/streaming-sync-types.ts:136](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/stream/streaming-sync-types.ts#L136) + +___ + +### isStreamingSyncCheckpointDiff + +▸ **isStreamingSyncCheckpointDiff**(`line`): line is StreamingSyncCheckpointDiff + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `line` | [`StreamingSyncLine`](modules.md#streamingsyncline) | + +#### Returns + +line is StreamingSyncCheckpointDiff + +#### Defined in + +[client/sync/stream/streaming-sync-types.ts:140](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/stream/streaming-sync-types.ts#L140) + +___ + +### isStreamingSyncData + +▸ **isStreamingSyncData**(`line`): line is StreamingSyncDataJSON + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `line` | [`StreamingSyncLine`](modules.md#streamingsyncline) | + +#### Returns + +line is StreamingSyncDataJSON + +#### Defined in + +[client/sync/stream/streaming-sync-types.ts:124](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/stream/streaming-sync-types.ts#L124) + +___ + +### isSyncNewCheckpointRequest + +▸ **isSyncNewCheckpointRequest**(`request`): request is SyncNewCheckpointRequest + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `request` | [`SyncRequest`](modules.md#syncrequest) | + +#### Returns + +request is SyncNewCheckpointRequest + +#### Defined in + +[client/sync/stream/streaming-sync-types.ts:151](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/client/sync/stream/streaming-sync-types.ts#L151) + +___ + +### quoteJsonPath + +▸ **quoteJsonPath**(`path`): `string` + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `path` | `string` | + +#### Returns + +`string` + +#### Defined in + +[utils/strings.ts:5](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/utils/strings.ts#L5) + +___ + +### quoteString + +▸ **quoteString**(`s`): `string` + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `s` | `string` | + +#### Returns + +`string` + +#### Defined in + +[utils/strings.ts:1](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-common/src/utils/strings.ts#L1) diff --git a/docs/docs/index.md b/docs/docs/index.md new file mode 100644 index 00000000..1d728e27 --- /dev/null +++ b/docs/docs/index.md @@ -0,0 +1,94 @@ +--- +id: "index" +title: "PowerSync React Native SDK Docs" +sidebar_label: "Readme" +sidebar_position: 0 +custom_edit_url: null +--- + +# PowerSync React Native SDK + +Monorepo for all things React Native and PowerSync. + +## Monorepo Structure + +- [apps/supabase-todolist](https://github.com/powersync-ja/powersync-supabase-react-native-todolist-demo/tree/e6a1d045ab8244041651757402adc562a6699a4f) + - An Expo React native app using Supabase. + +- [packages/powersync-sdk-common](./packages/powersync-sdk-common/README.md) + - A Typescript implementation of a PowerSync database connector and streaming sync bucket implementation. + +- [packages/powersync-sdk-react-native](./packages/powersync-sdk-react-native/README.md) + - An extension of `packages/powersync-sdk-common` which provides React Native specific implementations of abstracted features. + +# Development + +## Git Submodules + +After cloning this repo be sure to init the Git submodules + +```bash +git submodule init && git submodule update +``` + +This monorepo uses Yarn as it works well with React native. + +Install workspace dependencies + +```bash +yarn install +``` + +Build packages + +```bash +yarn build:packages +``` + +## Versioning + +### Development Packages + +Development packages can be published by manually triggering the `dev-packages` workflow. Development packages are versioned as `0.0.0-{tag}-DATETIMESTAMP`. + +### Production Packages + +Pull requests should contain Changesets for changed packages. + +Add changesets with + +```Bash +yarn changeset add +``` + +Merging a PR with Changesets will automatically create a PR with version bumps. That PR will be merged when releasing. + +## React Native Quick SQLite Development + +Testing live development changes to `@journeyapps/react-native-quick-sqlite` will not with with standard `yarn link` commands. Metro does not work well with symlinks . + +The process of releasing development packages for `@journeyapps/react-native-quick-sqlite` for each change can be tedious and slow. A faster (and hackier) method is to use [mtsl](https://www.npmjs.com/package/mtsl) which will watch and copy the package into this workspace's `node_modules`. + +```bash +npm install -g mtsl +``` + +```bash +mtsl add -s "[source path to your react-native-quick-sqlite repo folder]" -d "[this workspaces root node_modules folder]"/@journeyapps/react-native-quick-sqlite +``` + +```bash +mtsl start "[the id returned from step above]" +``` + +## Testing Supabase example app + +``` bash +cd apps/supabase-todolist +``` + +Test on either Android or iOS + +```bash +yarn ios +``` diff --git a/docs/docs/react-native-sdk/_category_.yml b/docs/docs/react-native-sdk/_category_.yml new file mode 100644 index 00000000..24a46026 --- /dev/null +++ b/docs/docs/react-native-sdk/_category_.yml @@ -0,0 +1 @@ +label: "API" \ No newline at end of file diff --git a/docs/docs/react-native-sdk/classes/AbstractPowerSyncDatabase.md b/docs/docs/react-native-sdk/classes/AbstractPowerSyncDatabase.md new file mode 100644 index 00000000..769e96ed --- /dev/null +++ b/docs/docs/react-native-sdk/classes/AbstractPowerSyncDatabase.md @@ -0,0 +1,802 @@ +--- +id: "AbstractPowerSyncDatabase" +title: "Class: AbstractPowerSyncDatabase" +sidebar_label: "AbstractPowerSyncDatabase" +sidebar_position: 0 +custom_edit_url: null +--- + +## Hierarchy + +- [`BaseObserver`](BaseObserver.md)<[`PowerSyncDBListener`](../interfaces/PowerSyncDBListener.md)\> + + ↳ **`AbstractPowerSyncDatabase`** + + ↳↳ [`PowerSyncDatabase`](PowerSyncDatabase.md) + +## Constructors + +### constructor + +• **new AbstractPowerSyncDatabase**(`options`): [`AbstractPowerSyncDatabase`](AbstractPowerSyncDatabase.md) + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `options` | [`PowerSyncDatabaseOptions`](../interfaces/PowerSyncDatabaseOptions.md) | + +#### Returns + +[`AbstractPowerSyncDatabase`](AbstractPowerSyncDatabase.md) + +#### Overrides + +[BaseObserver](BaseObserver.md).[constructor](BaseObserver.md#constructor) + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncDatabase.d.ts:58 + +## Properties + +### \_isReadyPromise + +• `Protected` **\_isReadyPromise**: `Promise`<`void`\> + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncDatabase.d.ts:57 + +___ + +### abortController + +• `Private` **abortController**: `any` + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncDatabase.d.ts:54 + +___ + +### bucketStorageAdapter + +• `Protected` **bucketStorageAdapter**: [`BucketStorageAdapter`](../interfaces/BucketStorageAdapter.md) + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncDatabase.d.ts:55 + +___ + +### closed + +• **closed**: `boolean` + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncDatabase.d.ts:49 + +___ + +### currentStatus + +• `Optional` **currentStatus**: [`SyncStatus`](SyncStatus.md) + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncDatabase.d.ts:51 + +___ + +### executeReadOnly + +• `Private` **executeReadOnly**: `any` + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncDatabase.d.ts:171 + +___ + +### listeners + +• `Protected` **listeners**: `Object` + +#### Index signature + +▪ [id: `string`]: `Partial`<`T`\> + +#### Inherited from + +[BaseObserver](BaseObserver.md).[listeners](BaseObserver.md#listeners) + +#### Defined in + +powersync-sdk-common/lib/utils/BaseObserver.d.ts:8 + +___ + +### options + +• `Protected` **options**: [`PowerSyncDatabaseOptions`](../interfaces/PowerSyncDatabaseOptions.md) + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncDatabase.d.ts:43 + +___ + +### ready + +• **ready**: `boolean` + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncDatabase.d.ts:50 + +___ + +### sdkVersion + +• **sdkVersion**: `string` + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncDatabase.d.ts:53 + +___ + +### syncStatusListenerDisposer + +• `Private` `Optional` **syncStatusListenerDisposer**: `any` + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncDatabase.d.ts:56 + +___ + +### syncStreamImplementation + +• `Optional` **syncStreamImplementation**: [`AbstractStreamingSyncImplementation`](AbstractStreamingSyncImplementation.md) + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncDatabase.d.ts:52 + +___ + +### transactionMutex + +▪ `Static` `Protected` **transactionMutex**: `Mutex` + +Transactions should be queued in the DBAdapter, but we also want to prevent +calls to `.execute` while an async transaction is running. + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncDatabase.d.ts:48 + +## Accessors + +### connected + +• `get` **connected**(): `boolean` + +#### Returns + +`boolean` + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncDatabase.d.ts:61 + +___ + +### database + +• `get` **database**(): [`DBAdapter`](../interfaces/DBAdapter.md) + +#### Returns + +[`DBAdapter`](../interfaces/DBAdapter.md) + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncDatabase.d.ts:60 + +___ + +### schema + +• `get` **schema**(): [`Schema`](Schema.md) + +#### Returns + +[`Schema`](Schema.md) + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncDatabase.d.ts:59 + +## Methods + +### \_initialize + +▸ **_initialize**(): `Promise`<`void`\> + +Allows for extended implementations to execute custom initialization +logic as part of the total init process + +#### Returns + +`Promise`<`void`\> + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncDatabase.d.ts:72 + +___ + +### close + +▸ **close**(): `Promise`<`void`\> + +#### Returns + +`Promise`<`void`\> + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncDatabase.d.ts:95 + +___ + +### connect + +▸ **connect**(`connector`): `Promise`<`void`\> + +Connects to stream of events from PowerSync instance + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `connector` | [`PowerSyncBackendConnector`](../interfaces/PowerSyncBackendConnector.md) | + +#### Returns + +`Promise`<`void`\> + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncDatabase.d.ts:86 + +___ + +### disconnect + +▸ **disconnect**(): `Promise`<`void`\> + +#### Returns + +`Promise`<`void`\> + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncDatabase.d.ts:87 + +___ + +### disconnectAndClear + +▸ **disconnectAndClear**(): `Promise`<`void`\> + +Disconnect and clear the database. + Use this when logging out. + The database can still be queried after this is called, but the tables + would be empty. + +#### Returns + +`Promise`<`void`\> + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncDatabase.d.ts:94 + +___ + +### execute + +▸ **execute**(`sql`, `parameters?`): `Promise`<[`QueryResult`](../interfaces/QueryResult.md)\> + +Execute a statement and optionally return results + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `sql` | `string` | +| `parameters?` | `any`[] | + +#### Returns + +`Promise`<[`QueryResult`](../interfaces/QueryResult.md)\> + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncDatabase.d.ts:135 + +___ + +### generateBucketStorageAdapter + +▸ **generateBucketStorageAdapter**(): [`BucketStorageAdapter`](../interfaces/BucketStorageAdapter.md) + +#### Returns + +[`BucketStorageAdapter`](../interfaces/BucketStorageAdapter.md) + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncDatabase.d.ts:63 + +___ + +### generateSyncStreamImplementation + +▸ **generateSyncStreamImplementation**(`connector`): [`AbstractStreamingSyncImplementation`](AbstractStreamingSyncImplementation.md) + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `connector` | [`PowerSyncBackendConnector`](../interfaces/PowerSyncBackendConnector.md) | + +#### Returns + +[`AbstractStreamingSyncImplementation`](AbstractStreamingSyncImplementation.md) + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncDatabase.d.ts:62 + +___ + +### get + +▸ **get**<`T`\>(`sql`, `parameters?`): `Promise`<`T`\> + +Execute a read-only query and return the first result, error if the ResultSet is empty. + +#### Type parameters + +| Name | +| :------ | +| `T` | + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `sql` | `string` | +| `parameters?` | `any`[] | + +#### Returns + +`Promise`<`T`\> + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncDatabase.d.ts:147 + +___ + +### getAll + +▸ **getAll**<`T`\>(`sql`, `parameters?`): `Promise`<`T`[]\> + +Execute a read-only query and return results + +#### Type parameters + +| Name | +| :------ | +| `T` | + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `sql` | `string` | +| `parameters?` | `any`[] | + +#### Returns + +`Promise`<`T`[]\> + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncDatabase.d.ts:139 + +___ + +### getCrudBatch + +▸ **getCrudBatch**(`limit`): `Promise`<[`CrudBatch`](CrudBatch.md)\> + +Get a batch of crud data to upload. + +Returns null if there is no data to upload. + +Use this from the [PowerSyncBackendConnector.uploadData]` callback. + +Once the data have been successfully uploaded, call [CrudBatch.complete] before +requesting the next batch. + +Use [limit] to specify the maximum number of updates to return in a single +batch. + +This method does include transaction ids in the result, but does not group +data by transaction. One batch may contain data from multiple transactions, +and a single transaction may be split over multiple batches. + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `limit` | `number` | + +#### Returns + +`Promise`<[`CrudBatch`](CrudBatch.md)\> + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncDatabase.d.ts:117 + +___ + +### getNextCrudTransaction + +▸ **getNextCrudTransaction**(): `Promise`<[`CrudTransaction`](CrudTransaction.md)\> + +Get the next recorded transaction to upload. + +Returns null if there is no data to upload. + +Use this from the [PowerSyncBackendConnector.uploadData]` callback. + +Once the data have been successfully uploaded, call [CrudTransaction.complete] before +requesting the next transaction. + +Unlike [getCrudBatch], this only returns data from a single transaction at a time. +All data for the transaction is loaded into memory. + +#### Returns + +`Promise`<[`CrudTransaction`](CrudTransaction.md)\> + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncDatabase.d.ts:131 + +___ + +### getOptional + +▸ **getOptional**<`T`\>(`sql`, `parameters?`): `Promise`<`T`\> + +Execute a read-only query and return the first result, or null if the ResultSet is empty. + +#### Type parameters + +| Name | +| :------ | +| `T` | + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `sql` | `string` | +| `parameters?` | `any`[] | + +#### Returns + +`Promise`<`T`\> + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncDatabase.d.ts:143 + +___ + +### getUploadQueueStats + +▸ **getUploadQueueStats**(`includeSize?`): `Promise`<[`UploadQueueStats`](UploadQueueStats.md)\> + +Get upload queue size estimate and count. + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `includeSize?` | `boolean` | + +#### Returns + +`Promise`<[`UploadQueueStats`](UploadQueueStats.md)\> + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncDatabase.d.ts:99 + +___ + +### init + +▸ **init**(): `Promise`<`void`\> + +Wait for initialization to complete. +While initializing is automatic, this helps to catch and report initialization errors. + +#### Returns + +`Promise`<`void`\> + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncDatabase.d.ts:82 + +___ + +### initialize + +▸ **initialize**(): `Promise`<`void`\> + +Entry point for executing initialization logic. +This is to be automatically executed in the constructor. + +#### Returns + +`Promise`<`void`\> + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncDatabase.d.ts:77 + +___ + +### iterateListeners + +▸ **iterateListeners**(`cb`): `void` + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `cb` | (`listener`: `Partial`<[`PowerSyncDBListener`](../interfaces/PowerSyncDBListener.md)\>) => `any` | + +#### Returns + +`void` + +#### Inherited from + +[BaseObserver](BaseObserver.md).[iterateListeners](BaseObserver.md#iteratelisteners) + +#### Defined in + +powersync-sdk-common/lib/utils/BaseObserver.d.ts:13 + +___ + +### onChange + +▸ **onChange**(`options?`): `AsyncIterable`<[`WatchOnChangeEvent`](../interfaces/WatchOnChangeEvent.md)\> + +Create a Stream of changes to any of the specified tables. + +This is preferred over [watch] when multiple queries need to be performed +together when data is changed. + +Note, do not declare this as `async *onChange` as it will not work in React Native + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `options?` | [`SQLWatchOptions`](../interfaces/SQLWatchOptions.md) | + +#### Returns + +`AsyncIterable`<[`WatchOnChangeEvent`](../interfaces/WatchOnChangeEvent.md)\> + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncDatabase.d.ts:170 + +___ + +### readLock + +▸ **readLock**<`T`\>(`callback`): `Promise`<`T`\> + +Takes a read lock, without starting a transaction. + +In most cases, [readTransaction] should be used instead. + +#### Type parameters + +| Name | +| :------ | +| `T` | + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `callback` | (`db`: [`DBAdapter`](../interfaces/DBAdapter.md)) => `Promise`<`T`\> | + +#### Returns + +`Promise`<`T`\> + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncDatabase.d.ts:153 + +___ + +### readTransaction + +▸ **readTransaction**<`T`\>(`callback`, `lockTimeout?`): `Promise`<`T`\> + +#### Type parameters + +| Name | +| :------ | +| `T` | + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `callback` | (`tx`: [`Transaction`](../interfaces/Transaction.md)) => `Promise`<`T`\> | +| `lockTimeout?` | `number` | + +#### Returns + +`Promise`<`T`\> + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncDatabase.d.ts:159 + +___ + +### registerListener + +▸ **registerListener**(`listener`): () => `void` + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `listener` | `Partial`<[`PowerSyncDBListener`](../interfaces/PowerSyncDBListener.md)\> | + +#### Returns + +`fn` + +▸ (): `void` + +##### Returns + +`void` + +#### Inherited from + +[BaseObserver](BaseObserver.md).[registerListener](BaseObserver.md#registerlistener) + +#### Defined in + +powersync-sdk-common/lib/utils/BaseObserver.d.ts:12 + +___ + +### waitForReady + +▸ **waitForReady**(): `Promise`<`void`\> + +#### Returns + +`Promise`<`void`\> + +A promise which will resolve once initialization is completed. + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncDatabase.d.ts:67 + +___ + +### watch + +▸ **watch**(`sql`, `parameters?`, `options?`): `AsyncIterable`<[`QueryResult`](../interfaces/QueryResult.md)\> + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `sql` | `string` | +| `parameters?` | `any`[] | +| `options?` | [`SQLWatchOptions`](../interfaces/SQLWatchOptions.md) | + +#### Returns + +`AsyncIterable`<[`QueryResult`](../interfaces/QueryResult.md)\> + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncDatabase.d.ts:161 + +___ + +### writeLock + +▸ **writeLock**<`T`\>(`callback`): `Promise`<`T`\> + +Takes a global lock, without starting a transaction. +In most cases, [writeTransaction] should be used instead. + +#### Type parameters + +| Name | +| :------ | +| `T` | + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `callback` | (`db`: [`DBAdapter`](../interfaces/DBAdapter.md)) => `Promise`<`T`\> | + +#### Returns + +`Promise`<`T`\> + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncDatabase.d.ts:158 + +___ + +### writeTransaction + +▸ **writeTransaction**<`T`\>(`callback`, `lockTimeout?`): `Promise`<`T`\> + +#### Type parameters + +| Name | +| :------ | +| `T` | + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `callback` | (`tx`: [`Transaction`](../interfaces/Transaction.md)) => `Promise`<`T`\> | +| `lockTimeout?` | `number` | + +#### Returns + +`Promise`<`T`\> + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncDatabase.d.ts:160 diff --git a/docs/docs/react-native-sdk/classes/AbstractPowerSyncDatabaseOpenFactory.md b/docs/docs/react-native-sdk/classes/AbstractPowerSyncDatabaseOpenFactory.md new file mode 100644 index 00000000..78c6a6e7 --- /dev/null +++ b/docs/docs/react-native-sdk/classes/AbstractPowerSyncDatabaseOpenFactory.md @@ -0,0 +1,119 @@ +--- +id: "AbstractPowerSyncDatabaseOpenFactory" +title: "Class: AbstractPowerSyncDatabaseOpenFactory" +sidebar_label: "AbstractPowerSyncDatabaseOpenFactory" +sidebar_position: 0 +custom_edit_url: null +--- + +## Hierarchy + +- **`AbstractPowerSyncDatabaseOpenFactory`** + + ↳ [`RNQSPowerSyncDatabaseOpenFactory`](RNQSPowerSyncDatabaseOpenFactory.md) + +## Constructors + +### constructor + +• **new AbstractPowerSyncDatabaseOpenFactory**(`options`): [`AbstractPowerSyncDatabaseOpenFactory`](AbstractPowerSyncDatabaseOpenFactory.md) + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `options` | [`PowerSyncOpenFactoryOptions`](../interfaces/PowerSyncOpenFactoryOptions.md) | + +#### Returns + +[`AbstractPowerSyncDatabaseOpenFactory`](AbstractPowerSyncDatabaseOpenFactory.md) + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncOpenFactory.d.ts:17 + +## Properties + +### options + +• `Protected` **options**: [`PowerSyncOpenFactoryOptions`](../interfaces/PowerSyncOpenFactoryOptions.md) + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncOpenFactory.d.ts:16 + +## Accessors + +### schema + +• `get` **schema**(): [`Schema`](Schema.md) + +#### Returns + +[`Schema`](Schema.md) + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncOpenFactory.d.ts:18 + +## Methods + +### generateInstance + +▸ **generateInstance**(`options`): [`AbstractPowerSyncDatabase`](AbstractPowerSyncDatabase.md) + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `options` | [`PowerSyncDatabaseOptions`](../interfaces/PowerSyncDatabaseOptions.md) | + +#### Returns + +[`AbstractPowerSyncDatabase`](AbstractPowerSyncDatabase.md) + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncOpenFactory.d.ts:21 + +___ + +### generateOptions + +▸ **generateOptions**(): [`PowerSyncDatabaseOptions`](../interfaces/PowerSyncDatabaseOptions.md) + +#### Returns + +[`PowerSyncDatabaseOptions`](../interfaces/PowerSyncDatabaseOptions.md) + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncOpenFactory.d.ts:20 + +___ + +### getInstance + +▸ **getInstance**(): [`AbstractPowerSyncDatabase`](AbstractPowerSyncDatabase.md) + +#### Returns + +[`AbstractPowerSyncDatabase`](AbstractPowerSyncDatabase.md) + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncOpenFactory.d.ts:22 + +___ + +### openDB + +▸ **openDB**(): [`DBAdapter`](../interfaces/DBAdapter.md) + +#### Returns + +[`DBAdapter`](../interfaces/DBAdapter.md) + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncOpenFactory.d.ts:19 diff --git a/docs/docs/react-native-sdk/classes/AbstractRemote.md b/docs/docs/react-native-sdk/classes/AbstractRemote.md new file mode 100644 index 00000000..ef17dea5 --- /dev/null +++ b/docs/docs/react-native-sdk/classes/AbstractRemote.md @@ -0,0 +1,186 @@ +--- +id: "AbstractRemote" +title: "Class: AbstractRemote" +sidebar_label: "AbstractRemote" +sidebar_position: 0 +custom_edit_url: null +--- + +## Hierarchy + +- **`AbstractRemote`** + + ↳ [`ReactNativeRemote`](ReactNativeRemote.md) + +## Constructors + +### constructor + +• **new AbstractRemote**(`connector`, `logger?`): [`AbstractRemote`](AbstractRemote.md) + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `connector` | [`RemoteConnector`](../modules.md#remoteconnector) | +| `logger?` | `ILogger` | + +#### Returns + +[`AbstractRemote`](AbstractRemote.md) + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/AbstractRemote.d.ts:12 + +## Properties + +### connector + +• `Protected` **connector**: [`RemoteConnector`](../modules.md#remoteconnector) + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/AbstractRemote.d.ts:9 + +___ + +### credentials + +• `Protected` `Optional` **credentials**: [`PowerSyncCredentials`](../interfaces/PowerSyncCredentials.md) + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/AbstractRemote.d.ts:11 + +___ + +### logger + +• `Protected` **logger**: `ILogger` + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/AbstractRemote.d.ts:10 + +## Methods + +### get + +▸ **get**(`path`, `headers?`): `Promise`<`any`\> + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `path` | `string` | +| `headers?` | `Record`<`string`, `string`\> | + +#### Returns + +`Promise`<`any`\> + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/AbstractRemote.d.ts:20 + +___ + +### getCredentials + +▸ **getCredentials**(): `Promise`<[`PowerSyncCredentials`](../interfaces/PowerSyncCredentials.md)\> + +#### Returns + +`Promise`<[`PowerSyncCredentials`](../interfaces/PowerSyncCredentials.md)\> + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/AbstractRemote.d.ts:13 + +___ + +### getHeaders + +▸ **getHeaders**(): `Promise`<\{ `Authorization`: `string` ; `content-type`: `string` }\> + +#### Returns + +`Promise`<\{ `Authorization`: `string` ; `content-type`: `string` }\> + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/AbstractRemote.d.ts:15 + +___ + +### getToken + +▸ **getToken**(): `Promise`<`string`\> + +#### Returns + +`Promise`<`string`\> + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/AbstractRemote.d.ts:14 + +___ + +### isAvailable + +▸ **isAvailable**(): `boolean` + +#### Returns + +`boolean` + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/AbstractRemote.d.ts:22 + +___ + +### post + +▸ **post**(`path`, `data`, `headers?`): `Promise`<`any`\> + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `path` | `string` | +| `data` | `any` | +| `headers?` | `Record`<`string`, `string`\> | + +#### Returns + +`Promise`<`any`\> + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/AbstractRemote.d.ts:19 + +___ + +### postStreaming + +▸ **postStreaming**(`path`, `data`, `headers?`, `signal?`): `Promise`<`any`\> + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `path` | `string` | +| `data` | `any` | +| `headers?` | `Record`<`string`, `string`\> | +| `signal?` | `AbortSignal` | + +#### Returns + +`Promise`<`any`\> + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/AbstractRemote.d.ts:21 diff --git a/docs/docs/react-native-sdk/classes/AbstractStreamingSyncImplementation.md b/docs/docs/react-native-sdk/classes/AbstractStreamingSyncImplementation.md new file mode 100644 index 00000000..38c13d56 --- /dev/null +++ b/docs/docs/react-native-sdk/classes/AbstractStreamingSyncImplementation.md @@ -0,0 +1,371 @@ +--- +id: "AbstractStreamingSyncImplementation" +title: "Class: AbstractStreamingSyncImplementation" +sidebar_label: "AbstractStreamingSyncImplementation" +sidebar_position: 0 +custom_edit_url: null +--- + +## Hierarchy + +- [`BaseObserver`](BaseObserver.md)<[`StreamingSyncImplementationListener`](../interfaces/StreamingSyncImplementationListener.md)\> + + ↳ **`AbstractStreamingSyncImplementation`** + + ↳↳ [`ReactNativeStreamingSyncImplementation`](ReactNativeStreamingSyncImplementation.md) + +## Constructors + +### constructor + +• **new AbstractStreamingSyncImplementation**(`options`): [`AbstractStreamingSyncImplementation`](AbstractStreamingSyncImplementation.md) + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `options` | [`AbstractStreamingSyncImplementationOptions`](../interfaces/AbstractStreamingSyncImplementationOptions.md) | + +#### Returns + +[`AbstractStreamingSyncImplementation`](AbstractStreamingSyncImplementation.md) + +#### Overrides + +[BaseObserver](BaseObserver.md).[constructor](BaseObserver.md#constructor) + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/AbstractStreamingSyncImplementation.d.ts:39 + +## Properties + +### \_isConnected + +• `Protected` **\_isConnected**: `boolean` + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/AbstractStreamingSyncImplementation.d.ts:38 + +___ + +### \_lastSyncedAt + +• `Protected` **\_lastSyncedAt**: `Date` + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/AbstractStreamingSyncImplementation.d.ts:35 + +___ + +### delayRetry + +• `Private` **delayRetry**: `any` + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/AbstractStreamingSyncImplementation.d.ts:55 + +___ + +### isUploadingCrud + +• `Private` **isUploadingCrud**: `any` + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/AbstractStreamingSyncImplementation.d.ts:37 + +___ + +### listeners + +• `Protected` **listeners**: `Object` + +#### Index signature + +▪ [id: `string`]: `Partial`<`T`\> + +#### Inherited from + +[BaseObserver](BaseObserver.md).[listeners](BaseObserver.md#listeners) + +#### Defined in + +powersync-sdk-common/lib/utils/BaseObserver.d.ts:8 + +___ + +### options + +• `Protected` **options**: [`AbstractStreamingSyncImplementationOptions`](../interfaces/AbstractStreamingSyncImplementationOptions.md) + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/AbstractStreamingSyncImplementation.d.ts:36 + +___ + +### updateSyncStatus + +• `Private` **updateSyncStatus**: `any` + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/AbstractStreamingSyncImplementation.d.ts:54 + +## Accessors + +### isConnected + +• `get` **isConnected**(): `boolean` + +#### Returns + +`boolean` + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/AbstractStreamingSyncImplementation.d.ts:42 + +___ + +### lastSyncedAt + +• `get` **lastSyncedAt**(): `Date` + +#### Returns + +`Date` + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/AbstractStreamingSyncImplementation.d.ts:40 + +___ + +### logger + +• `get` **logger**(): `ILogger` + +#### Returns + +`ILogger` + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/AbstractStreamingSyncImplementation.d.ts:41 + +## Methods + +### \_uploadAllCrud + +▸ **_uploadAllCrud**(): `Promise`<`void`\> + +#### Returns + +`Promise`<`void`\> + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/AbstractStreamingSyncImplementation.d.ts:46 + +___ + +### getWriteCheckpoint + +▸ **getWriteCheckpoint**(): `Promise`<`string`\> + +#### Returns + +`Promise`<`string`\> + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/AbstractStreamingSyncImplementation.d.ts:48 + +___ + +### hasCompletedSync + +▸ **hasCompletedSync**(): `Promise`<`boolean`\> + +#### Returns + +`Promise`<`boolean`\> + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/AbstractStreamingSyncImplementation.d.ts:44 + +___ + +### iterateListeners + +▸ **iterateListeners**(`cb`): `void` + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `cb` | (`listener`: `Partial`<[`StreamingSyncImplementationListener`](../interfaces/StreamingSyncImplementationListener.md)\>) => `any` | + +#### Returns + +`void` + +#### Inherited from + +[BaseObserver](BaseObserver.md).[iterateListeners](BaseObserver.md#iteratelisteners) + +#### Defined in + +powersync-sdk-common/lib/utils/BaseObserver.d.ts:13 + +___ + +### obtainLock + +▸ **obtainLock**<`T`\>(`lockOptions`): `Promise`<`T`\> + +#### Type parameters + +| Name | +| :------ | +| `T` | + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `lockOptions` | [`LockOptions`](../interfaces/LockOptions.md)<`T`\> | + +#### Returns + +`Promise`<`T`\> + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/AbstractStreamingSyncImplementation.d.ts:43 + +___ + +### registerListener + +▸ **registerListener**(`listener`): () => `void` + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `listener` | `Partial`<[`StreamingSyncImplementationListener`](../interfaces/StreamingSyncImplementationListener.md)\> | + +#### Returns + +`fn` + +▸ (): `void` + +##### Returns + +`void` + +#### Inherited from + +[BaseObserver](BaseObserver.md).[registerListener](BaseObserver.md#registerlistener) + +#### Defined in + +powersync-sdk-common/lib/utils/BaseObserver.d.ts:12 + +___ + +### streamingSync + +▸ **streamingSync**(`signal?`): `Promise`<`void`\> + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `signal?` | `AbortSignal` | + +#### Returns + +`Promise`<`void`\> + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/AbstractStreamingSyncImplementation.d.ts:49 + +___ + +### streamingSyncIteration + +▸ **streamingSyncIteration**(`signal?`, `progress?`): `Promise`<\{ `retry?`: `boolean` }\> + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `signal?` | `AbortSignal` | +| `progress?` | () => `void` | + +#### Returns + +`Promise`<\{ `retry?`: `boolean` }\> + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/AbstractStreamingSyncImplementation.d.ts:50 + +___ + +### streamingSyncRequest + +▸ **streamingSyncRequest**(`req`, `signal`): `AsyncGenerator`<[`StreamingSyncLine`](../modules.md#streamingsyncline), `any`, `unknown`\> + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `req` | [`StreamingSyncRequest`](../interfaces/StreamingSyncRequest.md) | +| `signal` | `AbortSignal` | + +#### Returns + +`AsyncGenerator`<[`StreamingSyncLine`](../modules.md#streamingsyncline), `any`, `unknown`\> + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/AbstractStreamingSyncImplementation.d.ts:53 + +___ + +### triggerCrudUpload + +▸ **triggerCrudUpload**(): `void` + +#### Returns + +`void` + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/AbstractStreamingSyncImplementation.d.ts:45 + +___ + +### uploadCrudBatch + +▸ **uploadCrudBatch**(): `Promise`<`boolean`\> + +#### Returns + +`Promise`<`boolean`\> + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/AbstractStreamingSyncImplementation.d.ts:47 diff --git a/docs/docs/react-native-sdk/classes/BaseObserver.md b/docs/docs/react-native-sdk/classes/BaseObserver.md new file mode 100644 index 00000000..fdf04d7f --- /dev/null +++ b/docs/docs/react-native-sdk/classes/BaseObserver.md @@ -0,0 +1,111 @@ +--- +id: "BaseObserver" +title: "Class: BaseObserver" +sidebar_label: "BaseObserver" +sidebar_position: 0 +custom_edit_url: null +--- + +## Type parameters + +| Name | Type | +| :------ | :------ | +| `T` | extends [`BaseListener`](../modules.md#baselistener) = [`BaseListener`](../modules.md#baselistener) | + +## Hierarchy + +- **`BaseObserver`** + + ↳ [`AbstractPowerSyncDatabase`](AbstractPowerSyncDatabase.md) + + ↳ [`AbstractStreamingSyncImplementation`](AbstractStreamingSyncImplementation.md) + + ↳ [`RNQSDBAdapter`](RNQSDBAdapter.md) + +## Implements + +- [`BaseObserverInterface`](../interfaces/BaseObserverInterface.md)<`T`\> + +## Constructors + +### constructor + +• **new BaseObserver**<`T`\>(): [`BaseObserver`](BaseObserver.md)<`T`\> + +#### Type parameters + +| Name | Type | +| :------ | :------ | +| `T` | extends [`BaseListener`](../modules.md#baselistener) = [`BaseListener`](../modules.md#baselistener) | + +#### Returns + +[`BaseObserver`](BaseObserver.md)<`T`\> + +#### Defined in + +powersync-sdk-common/lib/utils/BaseObserver.d.ts:11 + +## Properties + +### listeners + +• `Protected` **listeners**: `Object` + +#### Index signature + +▪ [id: `string`]: `Partial`<`T`\> + +#### Defined in + +powersync-sdk-common/lib/utils/BaseObserver.d.ts:8 + +## Methods + +### iterateListeners + +▸ **iterateListeners**(`cb`): `void` + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `cb` | (`listener`: `Partial`<`T`\>) => `any` | + +#### Returns + +`void` + +#### Defined in + +powersync-sdk-common/lib/utils/BaseObserver.d.ts:13 + +___ + +### registerListener + +▸ **registerListener**(`listener`): () => `void` + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `listener` | `Partial`<`T`\> | + +#### Returns + +`fn` + +▸ (): `void` + +##### Returns + +`void` + +#### Implementation of + +[BaseObserverInterface](../interfaces/BaseObserverInterface.md).[registerListener](../interfaces/BaseObserverInterface.md#registerlistener) + +#### Defined in + +powersync-sdk-common/lib/utils/BaseObserver.d.ts:12 diff --git a/docs/docs/react-native-sdk/classes/Column.md b/docs/docs/react-native-sdk/classes/Column.md new file mode 100644 index 00000000..603a307d --- /dev/null +++ b/docs/docs/react-native-sdk/classes/Column.md @@ -0,0 +1,84 @@ +--- +id: "Column" +title: "Class: Column" +sidebar_label: "Column" +sidebar_position: 0 +custom_edit_url: null +--- + +## Constructors + +### constructor + +• **new Column**(`options`): [`Column`](Column.md) + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `options` | [`ColumnOptions`](../interfaces/ColumnOptions.md) | + +#### Returns + +[`Column`](Column.md) + +#### Defined in + +powersync-sdk-common/lib/db/Column.d.ts:12 + +## Properties + +### options + +• `Protected` **options**: [`ColumnOptions`](../interfaces/ColumnOptions.md) + +#### Defined in + +powersync-sdk-common/lib/db/Column.d.ts:11 + +## Accessors + +### name + +• `get` **name**(): `string` + +#### Returns + +`string` + +#### Defined in + +powersync-sdk-common/lib/db/Column.d.ts:13 + +___ + +### type + +• `get` **type**(): [`ColumnType`](../enums/ColumnType.md) + +#### Returns + +[`ColumnType`](../enums/ColumnType.md) + +#### Defined in + +powersync-sdk-common/lib/db/Column.d.ts:14 + +## Methods + +### toJSON + +▸ **toJSON**(): `Object` + +#### Returns + +`Object` + +| Name | Type | +| :------ | :------ | +| `name` | `string` | +| `type` | [`ColumnType`](../enums/ColumnType.md) | + +#### Defined in + +powersync-sdk-common/lib/db/Column.d.ts:15 diff --git a/docs/docs/react-native-sdk/classes/CrudBatch.md b/docs/docs/react-native-sdk/classes/CrudBatch.md new file mode 100644 index 00000000..17548b34 --- /dev/null +++ b/docs/docs/react-native-sdk/classes/CrudBatch.md @@ -0,0 +1,79 @@ +--- +id: "CrudBatch" +title: "Class: CrudBatch" +sidebar_label: "CrudBatch" +sidebar_position: 0 +custom_edit_url: null +--- + +## Hierarchy + +- **`CrudBatch`** + + ↳ [`CrudTransaction`](CrudTransaction.md) + +## Constructors + +### constructor + +• **new CrudBatch**(`crud`, `haveMore`, `complete`): [`CrudBatch`](CrudBatch.md) + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `crud` | [`CrudEntry`](CrudEntry.md)[] | +| `haveMore` | `boolean` | +| `complete` | (`writeCheckpoint?`: `string`) => `Promise`<`void`\> | + +#### Returns + +[`CrudBatch`](CrudBatch.md) + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/CrudBatch.d.ts:6 + +## Properties + +### complete + +• **complete**: (`writeCheckpoint?`: `string`) => `Promise`<`void`\> + +#### Type declaration + +▸ (`writeCheckpoint?`): `Promise`<`void`\> + +##### Parameters + +| Name | Type | +| :------ | :------ | +| `writeCheckpoint?` | `string` | + +##### Returns + +`Promise`<`void`\> + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/CrudBatch.d.ts:5 + +___ + +### crud + +• **crud**: [`CrudEntry`](CrudEntry.md)[] + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/CrudBatch.d.ts:3 + +___ + +### haveMore + +• **haveMore**: `boolean` + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/CrudBatch.d.ts:4 diff --git a/docs/docs/react-native-sdk/classes/CrudEntry.md b/docs/docs/react-native-sdk/classes/CrudEntry.md new file mode 100644 index 00000000..74814b4f --- /dev/null +++ b/docs/docs/react-native-sdk/classes/CrudEntry.md @@ -0,0 +1,140 @@ +--- +id: "CrudEntry" +title: "Class: CrudEntry" +sidebar_label: "CrudEntry" +sidebar_position: 0 +custom_edit_url: null +--- + +## Constructors + +### constructor + +• **new CrudEntry**(`clientId`, `op`, `table`, `id`, `transactionId?`, `opData?`): [`CrudEntry`](CrudEntry.md) + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `clientId` | `number` | +| `op` | [`UpdateType`](../enums/UpdateType.md) | +| `table` | `string` | +| `id` | `string` | +| `transactionId?` | `number` | +| `opData?` | `Record`<`string`, `any`\> | + +#### Returns + +[`CrudEntry`](CrudEntry.md) + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/CrudEntry.d.ts:42 + +## Properties + +### clientId + +• **clientId**: `number` + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/CrudEntry.d.ts:35 + +___ + +### id + +• **id**: `string` + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/CrudEntry.d.ts:36 + +___ + +### op + +• **op**: [`UpdateType`](../enums/UpdateType.md) + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/CrudEntry.d.ts:37 + +___ + +### opData + +• `Optional` **opData**: `Record`<`string`, `any`\> + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/CrudEntry.d.ts:38 + +___ + +### table + +• **table**: `string` + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/CrudEntry.d.ts:39 + +___ + +### transactionId + +• `Optional` **transactionId**: `number` + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/CrudEntry.d.ts:40 + +## Methods + +### hashCode + +▸ **hashCode**(): `string` + +#### Returns + +`string` + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/CrudEntry.d.ts:44 + +___ + +### toJSON + +▸ **toJSON**(): [`CrudEntryOutputJSON`](../modules.md#crudentryoutputjson) + +#### Returns + +[`CrudEntryOutputJSON`](../modules.md#crudentryoutputjson) + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/CrudEntry.d.ts:43 + +___ + +### fromRow + +▸ **fromRow**(`dbRow`): [`CrudEntry`](CrudEntry.md) + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `dbRow` | [`CrudEntryJSON`](../modules.md#crudentryjson) | + +#### Returns + +[`CrudEntry`](CrudEntry.md) + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/CrudEntry.d.ts:41 diff --git a/docs/docs/react-native-sdk/classes/CrudTransaction.md b/docs/docs/react-native-sdk/classes/CrudTransaction.md new file mode 100644 index 00000000..8672a16f --- /dev/null +++ b/docs/docs/react-native-sdk/classes/CrudTransaction.md @@ -0,0 +1,105 @@ +--- +id: "CrudTransaction" +title: "Class: CrudTransaction" +sidebar_label: "CrudTransaction" +sidebar_position: 0 +custom_edit_url: null +--- + +## Hierarchy + +- [`CrudBatch`](CrudBatch.md) + + ↳ **`CrudTransaction`** + +## Constructors + +### constructor + +• **new CrudTransaction**(`crud`, `complete`, `transactionId?`): [`CrudTransaction`](CrudTransaction.md) + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `crud` | [`CrudEntry`](CrudEntry.md)[] | +| `complete` | (`checkpoint?`: `string`) => `Promise`<`void`\> | +| `transactionId?` | `number` | + +#### Returns + +[`CrudTransaction`](CrudTransaction.md) + +#### Overrides + +[CrudBatch](CrudBatch.md).[constructor](CrudBatch.md#constructor) + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/CrudTransaction.d.ts:7 + +## Properties + +### complete + +• **complete**: (`checkpoint?`: `string`) => `Promise`<`void`\> + +#### Type declaration + +▸ (`checkpoint?`): `Promise`<`void`\> + +##### Parameters + +| Name | Type | +| :------ | :------ | +| `checkpoint?` | `string` | + +##### Returns + +`Promise`<`void`\> + +#### Overrides + +[CrudBatch](CrudBatch.md).[complete](CrudBatch.md#complete) + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/CrudTransaction.d.ts:5 + +___ + +### crud + +• **crud**: [`CrudEntry`](CrudEntry.md)[] + +#### Overrides + +[CrudBatch](CrudBatch.md).[crud](CrudBatch.md#crud) + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/CrudTransaction.d.ts:4 + +___ + +### haveMore + +• **haveMore**: `boolean` + +#### Inherited from + +[CrudBatch](CrudBatch.md).[haveMore](CrudBatch.md#havemore) + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/CrudBatch.d.ts:4 + +___ + +### transactionId + +• `Optional` **transactionId**: `number` + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/CrudTransaction.d.ts:6 diff --git a/docs/docs/react-native-sdk/classes/Index.md b/docs/docs/react-native-sdk/classes/Index.md new file mode 100644 index 00000000..1f479a28 --- /dev/null +++ b/docs/docs/react-native-sdk/classes/Index.md @@ -0,0 +1,111 @@ +--- +id: "Index" +title: "Class: Index" +sidebar_label: "Index" +sidebar_position: 0 +custom_edit_url: null +--- + +## Constructors + +### constructor + +• **new Index**(`options`): [`Index`](Index.md) + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `options` | [`IndexOptions`](../interfaces/IndexOptions.md) | + +#### Returns + +[`Index`](Index.md) + +#### Defined in + +powersync-sdk-common/lib/db/schema/Index.d.ts:11 + +## Properties + +### options + +• `Protected` **options**: [`IndexOptions`](../interfaces/IndexOptions.md) + +#### Defined in + +powersync-sdk-common/lib/db/schema/Index.d.ts:9 + +## Accessors + +### columns + +• `get` **columns**(): [`IndexedColumn`](IndexedColumn.md)[] + +#### Returns + +[`IndexedColumn`](IndexedColumn.md)[] + +#### Defined in + +powersync-sdk-common/lib/db/schema/Index.d.ts:13 + +___ + +### name + +• `get` **name**(): `string` + +#### Returns + +`string` + +#### Defined in + +powersync-sdk-common/lib/db/schema/Index.d.ts:12 + +## Methods + +### toJSON + +▸ **toJSON**(`table`): `Object` + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `table` | [`Table`](Table.md) | + +#### Returns + +`Object` + +| Name | Type | +| :------ | :------ | +| `columns` | \{ `ascending`: `boolean` ; `name`: `string` ; `type`: [`ColumnType`](../enums/ColumnType.md) }[] | +| `name` | `string` | + +#### Defined in + +powersync-sdk-common/lib/db/schema/Index.d.ts:14 + +___ + +### createAscending + +▸ **createAscending**(`options`, `columnNames`): [`Index`](Index.md) + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `options` | [`IndexOptions`](../interfaces/IndexOptions.md) | +| `columnNames` | `string`[] | + +#### Returns + +[`Index`](Index.md) + +#### Defined in + +powersync-sdk-common/lib/db/schema/Index.d.ts:10 diff --git a/docs/docs/react-native-sdk/classes/IndexedColumn.md b/docs/docs/react-native-sdk/classes/IndexedColumn.md new file mode 100644 index 00000000..84536848 --- /dev/null +++ b/docs/docs/react-native-sdk/classes/IndexedColumn.md @@ -0,0 +1,111 @@ +--- +id: "IndexedColumn" +title: "Class: IndexedColumn" +sidebar_label: "IndexedColumn" +sidebar_position: 0 +custom_edit_url: null +--- + +## Constructors + +### constructor + +• **new IndexedColumn**(`options`): [`IndexedColumn`](IndexedColumn.md) + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `options` | [`IndexColumnOptions`](../interfaces/IndexColumnOptions.md) | + +#### Returns + +[`IndexedColumn`](IndexedColumn.md) + +#### Defined in + +powersync-sdk-common/lib/db/schema/IndexedColumn.d.ts:11 + +## Properties + +### options + +• `Protected` **options**: [`IndexColumnOptions`](../interfaces/IndexColumnOptions.md) + +#### Defined in + +powersync-sdk-common/lib/db/schema/IndexedColumn.d.ts:9 + +## Accessors + +### ascending + +• `get` **ascending**(): `boolean` + +#### Returns + +`boolean` + +#### Defined in + +powersync-sdk-common/lib/db/schema/IndexedColumn.d.ts:13 + +___ + +### name + +• `get` **name**(): `string` + +#### Returns + +`string` + +#### Defined in + +powersync-sdk-common/lib/db/schema/IndexedColumn.d.ts:12 + +## Methods + +### toJSON + +▸ **toJSON**(`table`): `Object` + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `table` | [`Table`](Table.md) | + +#### Returns + +`Object` + +| Name | Type | +| :------ | :------ | +| `ascending` | `boolean` | +| `name` | `string` | +| `type` | [`ColumnType`](../enums/ColumnType.md) | + +#### Defined in + +powersync-sdk-common/lib/db/schema/IndexedColumn.d.ts:14 + +___ + +### createAscending + +▸ **createAscending**(`column`): [`IndexedColumn`](IndexedColumn.md) + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `column` | `string` | + +#### Returns + +[`IndexedColumn`](IndexedColumn.md) + +#### Defined in + +powersync-sdk-common/lib/db/schema/IndexedColumn.d.ts:10 diff --git a/docs/docs/react-native-sdk/classes/OpType.md b/docs/docs/react-native-sdk/classes/OpType.md new file mode 100644 index 00000000..3ed83c06 --- /dev/null +++ b/docs/docs/react-native-sdk/classes/OpType.md @@ -0,0 +1,71 @@ +--- +id: "OpType" +title: "Class: OpType" +sidebar_label: "OpType" +sidebar_position: 0 +custom_edit_url: null +--- + +## Constructors + +### constructor + +• **new OpType**(`value`): [`OpType`](OpType.md) + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `value` | [`OpTypeEnum`](../enums/OpTypeEnum.md) | + +#### Returns + +[`OpType`](OpType.md) + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/OpType.d.ts:11 + +## Properties + +### value + +• **value**: [`OpTypeEnum`](../enums/OpTypeEnum.md) + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/OpType.d.ts:9 + +## Methods + +### toJSON + +▸ **toJSON**(): `string` + +#### Returns + +`string` + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/OpType.d.ts:12 + +___ + +### fromJSON + +▸ **fromJSON**(`jsonValue`): [`OpType`](OpType.md) + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `jsonValue` | `string` | + +#### Returns + +[`OpType`](OpType.md) + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/OpType.d.ts:10 diff --git a/docs/docs/react-native-sdk/classes/PowerSyncDatabase.md b/docs/docs/react-native-sdk/classes/PowerSyncDatabase.md new file mode 100644 index 00000000..ca1f686c --- /dev/null +++ b/docs/docs/react-native-sdk/classes/PowerSyncDatabase.md @@ -0,0 +1,910 @@ +--- +id: "PowerSyncDatabase" +title: "Class: PowerSyncDatabase" +sidebar_label: "PowerSyncDatabase" +sidebar_position: 0 +custom_edit_url: null +--- + +## Hierarchy + +- [`AbstractPowerSyncDatabase`](AbstractPowerSyncDatabase.md) + + ↳ **`PowerSyncDatabase`** + +## Constructors + +### constructor + +• **new PowerSyncDatabase**(`options`): [`PowerSyncDatabase`](PowerSyncDatabase.md) + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `options` | [`PowerSyncDatabaseOptions`](../interfaces/PowerSyncDatabaseOptions.md) | + +#### Returns + +[`PowerSyncDatabase`](PowerSyncDatabase.md) + +#### Inherited from + +[AbstractPowerSyncDatabase](AbstractPowerSyncDatabase.md).[constructor](AbstractPowerSyncDatabase.md#constructor) + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncDatabase.d.ts:58 + +## Properties + +### \_isReadyPromise + +• `Protected` **\_isReadyPromise**: `Promise`<`void`\> + +#### Inherited from + +[AbstractPowerSyncDatabase](AbstractPowerSyncDatabase.md).[_isReadyPromise](AbstractPowerSyncDatabase.md#_isreadypromise) + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncDatabase.d.ts:57 + +___ + +### bucketStorageAdapter + +• `Protected` **bucketStorageAdapter**: [`BucketStorageAdapter`](../interfaces/BucketStorageAdapter.md) + +#### Inherited from + +[AbstractPowerSyncDatabase](AbstractPowerSyncDatabase.md).[bucketStorageAdapter](AbstractPowerSyncDatabase.md#bucketstorageadapter) + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncDatabase.d.ts:55 + +___ + +### closed + +• **closed**: `boolean` + +#### Inherited from + +[AbstractPowerSyncDatabase](AbstractPowerSyncDatabase.md).[closed](AbstractPowerSyncDatabase.md#closed) + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncDatabase.d.ts:49 + +___ + +### currentStatus + +• `Optional` **currentStatus**: [`SyncStatus`](SyncStatus.md) + +#### Inherited from + +[AbstractPowerSyncDatabase](AbstractPowerSyncDatabase.md).[currentStatus](AbstractPowerSyncDatabase.md#currentstatus) + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncDatabase.d.ts:51 + +___ + +### listeners + +• `Protected` **listeners**: `Object` + +#### Index signature + +▪ [id: `string`]: `Partial`<`T`\> + +#### Inherited from + +[AbstractPowerSyncDatabase](AbstractPowerSyncDatabase.md).[listeners](AbstractPowerSyncDatabase.md#listeners) + +#### Defined in + +powersync-sdk-common/lib/utils/BaseObserver.d.ts:8 + +___ + +### options + +• `Protected` **options**: [`PowerSyncDatabaseOptions`](../interfaces/PowerSyncDatabaseOptions.md) + +#### Inherited from + +[AbstractPowerSyncDatabase](AbstractPowerSyncDatabase.md).[options](AbstractPowerSyncDatabase.md#options) + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncDatabase.d.ts:43 + +___ + +### ready + +• **ready**: `boolean` + +#### Inherited from + +[AbstractPowerSyncDatabase](AbstractPowerSyncDatabase.md).[ready](AbstractPowerSyncDatabase.md#ready) + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncDatabase.d.ts:50 + +___ + +### sdkVersion + +• **sdkVersion**: `string` + +#### Inherited from + +[AbstractPowerSyncDatabase](AbstractPowerSyncDatabase.md).[sdkVersion](AbstractPowerSyncDatabase.md#sdkversion) + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncDatabase.d.ts:53 + +___ + +### syncStreamImplementation + +• `Optional` **syncStreamImplementation**: [`AbstractStreamingSyncImplementation`](AbstractStreamingSyncImplementation.md) + +#### Inherited from + +[AbstractPowerSyncDatabase](AbstractPowerSyncDatabase.md).[syncStreamImplementation](AbstractPowerSyncDatabase.md#syncstreamimplementation) + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncDatabase.d.ts:52 + +___ + +### transactionMutex + +▪ `Static` `Protected` **transactionMutex**: `Mutex` + +Transactions should be queued in the DBAdapter, but we also want to prevent +calls to `.execute` while an async transaction is running. + +#### Inherited from + +[AbstractPowerSyncDatabase](AbstractPowerSyncDatabase.md).[transactionMutex](AbstractPowerSyncDatabase.md#transactionmutex) + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncDatabase.d.ts:48 + +## Accessors + +### connected + +• `get` **connected**(): `boolean` + +#### Returns + +`boolean` + +#### Inherited from + +AbstractPowerSyncDatabase.connected + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncDatabase.d.ts:61 + +___ + +### database + +• `get` **database**(): [`DBAdapter`](../interfaces/DBAdapter.md) + +#### Returns + +[`DBAdapter`](../interfaces/DBAdapter.md) + +#### Inherited from + +AbstractPowerSyncDatabase.database + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncDatabase.d.ts:60 + +___ + +### schema + +• `get` **schema**(): [`Schema`](Schema.md) + +#### Returns + +[`Schema`](Schema.md) + +#### Inherited from + +AbstractPowerSyncDatabase.schema + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncDatabase.d.ts:59 + +## Methods + +### \_initialize + +▸ **_initialize**(): `Promise`<`void`\> + +Allows for extended implementations to execute custom initialization +logic as part of the total init process + +#### Returns + +`Promise`<`void`\> + +#### Overrides + +[AbstractPowerSyncDatabase](AbstractPowerSyncDatabase.md).[_initialize](AbstractPowerSyncDatabase.md#_initialize) + +#### Defined in + +[powersync-sdk-react-native/src/db/PowerSyncDatabase.ts:12](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-react-native/src/db/PowerSyncDatabase.ts#L12) + +___ + +### close + +▸ **close**(): `Promise`<`void`\> + +#### Returns + +`Promise`<`void`\> + +#### Inherited from + +[AbstractPowerSyncDatabase](AbstractPowerSyncDatabase.md).[close](AbstractPowerSyncDatabase.md#close) + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncDatabase.d.ts:95 + +___ + +### connect + +▸ **connect**(`connector`): `Promise`<`void`\> + +Connects to stream of events from PowerSync instance + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `connector` | [`PowerSyncBackendConnector`](../interfaces/PowerSyncBackendConnector.md) | + +#### Returns + +`Promise`<`void`\> + +#### Inherited from + +[AbstractPowerSyncDatabase](AbstractPowerSyncDatabase.md).[connect](AbstractPowerSyncDatabase.md#connect) + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncDatabase.d.ts:86 + +___ + +### disconnect + +▸ **disconnect**(): `Promise`<`void`\> + +#### Returns + +`Promise`<`void`\> + +#### Inherited from + +[AbstractPowerSyncDatabase](AbstractPowerSyncDatabase.md).[disconnect](AbstractPowerSyncDatabase.md#disconnect) + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncDatabase.d.ts:87 + +___ + +### disconnectAndClear + +▸ **disconnectAndClear**(): `Promise`<`void`\> + +Disconnect and clear the database. + Use this when logging out. + The database can still be queried after this is called, but the tables + would be empty. + +#### Returns + +`Promise`<`void`\> + +#### Inherited from + +[AbstractPowerSyncDatabase](AbstractPowerSyncDatabase.md).[disconnectAndClear](AbstractPowerSyncDatabase.md#disconnectandclear) + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncDatabase.d.ts:94 + +___ + +### execute + +▸ **execute**(`sql`, `parameters?`): `Promise`<[`QueryResult`](../interfaces/QueryResult.md)\> + +Execute a statement and optionally return results + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `sql` | `string` | +| `parameters?` | `any`[] | + +#### Returns + +`Promise`<[`QueryResult`](../interfaces/QueryResult.md)\> + +#### Inherited from + +[AbstractPowerSyncDatabase](AbstractPowerSyncDatabase.md).[execute](AbstractPowerSyncDatabase.md#execute) + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncDatabase.d.ts:135 + +___ + +### generateBucketStorageAdapter + +▸ **generateBucketStorageAdapter**(): [`BucketStorageAdapter`](../interfaces/BucketStorageAdapter.md) + +#### Returns + +[`BucketStorageAdapter`](../interfaces/BucketStorageAdapter.md) + +#### Overrides + +[AbstractPowerSyncDatabase](AbstractPowerSyncDatabase.md).[generateBucketStorageAdapter](AbstractPowerSyncDatabase.md#generatebucketstorageadapter) + +#### Defined in + +[powersync-sdk-react-native/src/db/PowerSyncDatabase.ts:14](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-react-native/src/db/PowerSyncDatabase.ts#L14) + +___ + +### generateSyncStreamImplementation + +▸ **generateSyncStreamImplementation**(`connector`): [`AbstractStreamingSyncImplementation`](AbstractStreamingSyncImplementation.md) + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `connector` | [`PowerSyncBackendConnector`](../interfaces/PowerSyncBackendConnector.md) | + +#### Returns + +[`AbstractStreamingSyncImplementation`](AbstractStreamingSyncImplementation.md) + +#### Overrides + +[AbstractPowerSyncDatabase](AbstractPowerSyncDatabase.md).[generateSyncStreamImplementation](AbstractPowerSyncDatabase.md#generatesyncstreamimplementation) + +#### Defined in + +[powersync-sdk-react-native/src/db/PowerSyncDatabase.ts:18](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-react-native/src/db/PowerSyncDatabase.ts#L18) + +___ + +### get + +▸ **get**<`T`\>(`sql`, `parameters?`): `Promise`<`T`\> + +Execute a read-only query and return the first result, error if the ResultSet is empty. + +#### Type parameters + +| Name | +| :------ | +| `T` | + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `sql` | `string` | +| `parameters?` | `any`[] | + +#### Returns + +`Promise`<`T`\> + +#### Inherited from + +[AbstractPowerSyncDatabase](AbstractPowerSyncDatabase.md).[get](AbstractPowerSyncDatabase.md#get) + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncDatabase.d.ts:147 + +___ + +### getAll + +▸ **getAll**<`T`\>(`sql`, `parameters?`): `Promise`<`T`[]\> + +Execute a read-only query and return results + +#### Type parameters + +| Name | +| :------ | +| `T` | + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `sql` | `string` | +| `parameters?` | `any`[] | + +#### Returns + +`Promise`<`T`[]\> + +#### Inherited from + +[AbstractPowerSyncDatabase](AbstractPowerSyncDatabase.md).[getAll](AbstractPowerSyncDatabase.md#getall) + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncDatabase.d.ts:139 + +___ + +### getCrudBatch + +▸ **getCrudBatch**(`limit`): `Promise`<[`CrudBatch`](CrudBatch.md)\> + +Get a batch of crud data to upload. + +Returns null if there is no data to upload. + +Use this from the [PowerSyncBackendConnector.uploadData]` callback. + +Once the data have been successfully uploaded, call [CrudBatch.complete] before +requesting the next batch. + +Use [limit] to specify the maximum number of updates to return in a single +batch. + +This method does include transaction ids in the result, but does not group +data by transaction. One batch may contain data from multiple transactions, +and a single transaction may be split over multiple batches. + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `limit` | `number` | + +#### Returns + +`Promise`<[`CrudBatch`](CrudBatch.md)\> + +#### Inherited from + +[AbstractPowerSyncDatabase](AbstractPowerSyncDatabase.md).[getCrudBatch](AbstractPowerSyncDatabase.md#getcrudbatch) + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncDatabase.d.ts:117 + +___ + +### getNextCrudTransaction + +▸ **getNextCrudTransaction**(): `Promise`<[`CrudTransaction`](CrudTransaction.md)\> + +Get the next recorded transaction to upload. + +Returns null if there is no data to upload. + +Use this from the [PowerSyncBackendConnector.uploadData]` callback. + +Once the data have been successfully uploaded, call [CrudTransaction.complete] before +requesting the next transaction. + +Unlike [getCrudBatch], this only returns data from a single transaction at a time. +All data for the transaction is loaded into memory. + +#### Returns + +`Promise`<[`CrudTransaction`](CrudTransaction.md)\> + +#### Inherited from + +[AbstractPowerSyncDatabase](AbstractPowerSyncDatabase.md).[getNextCrudTransaction](AbstractPowerSyncDatabase.md#getnextcrudtransaction) + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncDatabase.d.ts:131 + +___ + +### getOptional + +▸ **getOptional**<`T`\>(`sql`, `parameters?`): `Promise`<`T`\> + +Execute a read-only query and return the first result, or null if the ResultSet is empty. + +#### Type parameters + +| Name | +| :------ | +| `T` | + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `sql` | `string` | +| `parameters?` | `any`[] | + +#### Returns + +`Promise`<`T`\> + +#### Inherited from + +[AbstractPowerSyncDatabase](AbstractPowerSyncDatabase.md).[getOptional](AbstractPowerSyncDatabase.md#getoptional) + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncDatabase.d.ts:143 + +___ + +### getUploadQueueStats + +▸ **getUploadQueueStats**(`includeSize?`): `Promise`<[`UploadQueueStats`](UploadQueueStats.md)\> + +Get upload queue size estimate and count. + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `includeSize?` | `boolean` | + +#### Returns + +`Promise`<[`UploadQueueStats`](UploadQueueStats.md)\> + +#### Inherited from + +[AbstractPowerSyncDatabase](AbstractPowerSyncDatabase.md).[getUploadQueueStats](AbstractPowerSyncDatabase.md#getuploadqueuestats) + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncDatabase.d.ts:99 + +___ + +### init + +▸ **init**(): `Promise`<`void`\> + +Wait for initialization to complete. +While initializing is automatic, this helps to catch and report initialization errors. + +#### Returns + +`Promise`<`void`\> + +#### Inherited from + +[AbstractPowerSyncDatabase](AbstractPowerSyncDatabase.md).[init](AbstractPowerSyncDatabase.md#init) + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncDatabase.d.ts:82 + +___ + +### initialize + +▸ **initialize**(): `Promise`<`void`\> + +Entry point for executing initialization logic. +This is to be automatically executed in the constructor. + +#### Returns + +`Promise`<`void`\> + +#### Inherited from + +[AbstractPowerSyncDatabase](AbstractPowerSyncDatabase.md).[initialize](AbstractPowerSyncDatabase.md#initialize) + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncDatabase.d.ts:77 + +___ + +### iterateListeners + +▸ **iterateListeners**(`cb`): `void` + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `cb` | (`listener`: `Partial`<[`PowerSyncDBListener`](../interfaces/PowerSyncDBListener.md)\>) => `any` | + +#### Returns + +`void` + +#### Inherited from + +[AbstractPowerSyncDatabase](AbstractPowerSyncDatabase.md).[iterateListeners](AbstractPowerSyncDatabase.md#iteratelisteners) + +#### Defined in + +powersync-sdk-common/lib/utils/BaseObserver.d.ts:13 + +___ + +### onChange + +▸ **onChange**(`options?`): `AsyncIterable`<[`WatchOnChangeEvent`](../interfaces/WatchOnChangeEvent.md)\> + +Create a Stream of changes to any of the specified tables. + +This is preferred over [watch] when multiple queries need to be performed +together when data is changed. + +Note, do not declare this as `async *onChange` as it will not work in React Native + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `options?` | [`SQLWatchOptions`](../interfaces/SQLWatchOptions.md) | + +#### Returns + +`AsyncIterable`<[`WatchOnChangeEvent`](../interfaces/WatchOnChangeEvent.md)\> + +#### Inherited from + +[AbstractPowerSyncDatabase](AbstractPowerSyncDatabase.md).[onChange](AbstractPowerSyncDatabase.md#onchange) + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncDatabase.d.ts:170 + +___ + +### readLock + +▸ **readLock**<`T`\>(`callback`): `Promise`<`T`\> + +Takes a read lock, without starting a transaction. + +In most cases, [readTransaction] should be used instead. + +#### Type parameters + +| Name | +| :------ | +| `T` | + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `callback` | (`db`: [`DBAdapter`](../interfaces/DBAdapter.md)) => `Promise`<`T`\> | + +#### Returns + +`Promise`<`T`\> + +#### Inherited from + +[AbstractPowerSyncDatabase](AbstractPowerSyncDatabase.md).[readLock](AbstractPowerSyncDatabase.md#readlock) + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncDatabase.d.ts:153 + +___ + +### readTransaction + +▸ **readTransaction**<`T`\>(`callback`, `lockTimeout?`): `Promise`<`T`\> + +#### Type parameters + +| Name | +| :------ | +| `T` | + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `callback` | (`tx`: [`Transaction`](../interfaces/Transaction.md)) => `Promise`<`T`\> | +| `lockTimeout?` | `number` | + +#### Returns + +`Promise`<`T`\> + +#### Inherited from + +[AbstractPowerSyncDatabase](AbstractPowerSyncDatabase.md).[readTransaction](AbstractPowerSyncDatabase.md#readtransaction) + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncDatabase.d.ts:159 + +___ + +### registerListener + +▸ **registerListener**(`listener`): () => `void` + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `listener` | `Partial`<[`PowerSyncDBListener`](../interfaces/PowerSyncDBListener.md)\> | + +#### Returns + +`fn` + +▸ (): `void` + +##### Returns + +`void` + +#### Inherited from + +[AbstractPowerSyncDatabase](AbstractPowerSyncDatabase.md).[registerListener](AbstractPowerSyncDatabase.md#registerlistener) + +#### Defined in + +powersync-sdk-common/lib/utils/BaseObserver.d.ts:12 + +___ + +### waitForReady + +▸ **waitForReady**(): `Promise`<`void`\> + +#### Returns + +`Promise`<`void`\> + +A promise which will resolve once initialization is completed. + +#### Inherited from + +[AbstractPowerSyncDatabase](AbstractPowerSyncDatabase.md).[waitForReady](AbstractPowerSyncDatabase.md#waitforready) + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncDatabase.d.ts:67 + +___ + +### watch + +▸ **watch**(`sql`, `parameters?`, `options?`): `AsyncIterable`<[`QueryResult`](../interfaces/QueryResult.md)\> + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `sql` | `string` | +| `parameters?` | `any`[] | +| `options?` | [`SQLWatchOptions`](../interfaces/SQLWatchOptions.md) | + +#### Returns + +`AsyncIterable`<[`QueryResult`](../interfaces/QueryResult.md)\> + +#### Inherited from + +[AbstractPowerSyncDatabase](AbstractPowerSyncDatabase.md).[watch](AbstractPowerSyncDatabase.md#watch) + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncDatabase.d.ts:161 + +___ + +### writeLock + +▸ **writeLock**<`T`\>(`callback`): `Promise`<`T`\> + +Takes a global lock, without starting a transaction. +In most cases, [writeTransaction] should be used instead. + +#### Type parameters + +| Name | +| :------ | +| `T` | + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `callback` | (`db`: [`DBAdapter`](../interfaces/DBAdapter.md)) => `Promise`<`T`\> | + +#### Returns + +`Promise`<`T`\> + +#### Inherited from + +[AbstractPowerSyncDatabase](AbstractPowerSyncDatabase.md).[writeLock](AbstractPowerSyncDatabase.md#writelock) + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncDatabase.d.ts:158 + +___ + +### writeTransaction + +▸ **writeTransaction**<`T`\>(`callback`, `lockTimeout?`): `Promise`<`T`\> + +#### Type parameters + +| Name | +| :------ | +| `T` | + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `callback` | (`tx`: [`Transaction`](../interfaces/Transaction.md)) => `Promise`<`T`\> | +| `lockTimeout?` | `number` | + +#### Returns + +`Promise`<`T`\> + +#### Inherited from + +[AbstractPowerSyncDatabase](AbstractPowerSyncDatabase.md).[writeTransaction](AbstractPowerSyncDatabase.md#writetransaction) + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncDatabase.d.ts:160 diff --git a/docs/docs/react-native-sdk/classes/RNQSDBAdapter.md b/docs/docs/react-native-sdk/classes/RNQSDBAdapter.md new file mode 100644 index 00000000..89ff57c7 --- /dev/null +++ b/docs/docs/react-native-sdk/classes/RNQSDBAdapter.md @@ -0,0 +1,455 @@ +--- +id: "RNQSDBAdapter" +title: "Class: RNQSDBAdapter" +sidebar_label: "RNQSDBAdapter" +sidebar_position: 0 +custom_edit_url: null +--- + +Adapter for React Native Quick SQLite + +## Hierarchy + +- [`BaseObserver`](BaseObserver.md)<[`DBAdapterListener`](../interfaces/DBAdapterListener.md)\> + + ↳ **`RNQSDBAdapter`** + +## Implements + +- [`DBAdapter`](../interfaces/DBAdapter.md) + +## Constructors + +### constructor + +• **new RNQSDBAdapter**(`baseDB`): [`RNQSDBAdapter`](RNQSDBAdapter.md) + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `baseDB` | `QuickSQLiteConnection` | + +#### Returns + +[`RNQSDBAdapter`](RNQSDBAdapter.md) + +#### Overrides + +[BaseObserver](BaseObserver.md).[constructor](BaseObserver.md#constructor) + +#### Defined in + +[powersync-sdk-react-native/src/db/adapters/react-native-quick-sqlite/RNQSDBAdapter.ts:21](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-react-native/src/db/adapters/react-native-quick-sqlite/RNQSDBAdapter.ts#L21) + +## Properties + +### baseDB + +• `Protected` **baseDB**: `QuickSQLiteConnection` + +#### Defined in + +[powersync-sdk-react-native/src/db/adapters/react-native-quick-sqlite/RNQSDBAdapter.ts:21](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-react-native/src/db/adapters/react-native-quick-sqlite/RNQSDBAdapter.ts#L21) + +___ + +### get + +• **get**: (`sql`: `string`, `parameters?`: `any`[]) => `Promise`<`T`\> + +#### Type declaration + +▸ <`T`\>(`sql`, `parameters?`): `Promise`<`T`\> + +##### Type parameters + +| Name | +| :------ | +| `T` | + +##### Parameters + +| Name | Type | +| :------ | :------ | +| `sql` | `string` | +| `parameters?` | `any`[] | + +##### Returns + +`Promise`<`T`\> + +#### Implementation of + +[DBAdapter](../interfaces/DBAdapter.md).[get](../interfaces/DBAdapter.md#get) + +#### Defined in + +[powersync-sdk-react-native/src/db/adapters/react-native-quick-sqlite/RNQSDBAdapter.ts:19](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-react-native/src/db/adapters/react-native-quick-sqlite/RNQSDBAdapter.ts#L19) + +___ + +### getAll + +• **getAll**: (`sql`: `string`, `parameters?`: `any`[]) => `Promise`<`T`[]\> + +#### Type declaration + +▸ <`T`\>(`sql`, `parameters?`): `Promise`<`T`[]\> + +##### Type parameters + +| Name | +| :------ | +| `T` | + +##### Parameters + +| Name | Type | +| :------ | :------ | +| `sql` | `string` | +| `parameters?` | `any`[] | + +##### Returns + +`Promise`<`T`[]\> + +#### Implementation of + +[DBAdapter](../interfaces/DBAdapter.md).[getAll](../interfaces/DBAdapter.md#getall) + +#### Defined in + +[powersync-sdk-react-native/src/db/adapters/react-native-quick-sqlite/RNQSDBAdapter.ts:17](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-react-native/src/db/adapters/react-native-quick-sqlite/RNQSDBAdapter.ts#L17) + +___ + +### getOptional + +• **getOptional**: (`sql`: `string`, `parameters?`: `any`[]) => `Promise`<`T`\> + +#### Type declaration + +▸ <`T`\>(`sql`, `parameters?`): `Promise`<`T`\> + +##### Type parameters + +| Name | +| :------ | +| `T` | + +##### Parameters + +| Name | Type | +| :------ | :------ | +| `sql` | `string` | +| `parameters?` | `any`[] | + +##### Returns + +`Promise`<`T`\> + +#### Implementation of + +[DBAdapter](../interfaces/DBAdapter.md).[getOptional](../interfaces/DBAdapter.md#getoptional) + +#### Defined in + +[powersync-sdk-react-native/src/db/adapters/react-native-quick-sqlite/RNQSDBAdapter.ts:18](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-react-native/src/db/adapters/react-native-quick-sqlite/RNQSDBAdapter.ts#L18) + +___ + +### listeners + +• `Protected` **listeners**: `Object` + +#### Index signature + +▪ [id: `string`]: `Partial`<`T`\> + +#### Inherited from + +[BaseObserver](BaseObserver.md).[listeners](BaseObserver.md#listeners) + +#### Defined in + +powersync-sdk-common/lib/utils/BaseObserver.d.ts:8 + +## Methods + +### close + +▸ **close**(): `void` + +#### Returns + +`void` + +#### Implementation of + +[DBAdapter](../interfaces/DBAdapter.md).[close](../interfaces/DBAdapter.md#close) + +#### Defined in + +[powersync-sdk-react-native/src/db/adapters/react-native-quick-sqlite/RNQSDBAdapter.ts:38](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-react-native/src/db/adapters/react-native-quick-sqlite/RNQSDBAdapter.ts#L38) + +___ + +### execute + +▸ **execute**(`query`, `params?`): `Promise`<`QueryResult`\> + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `query` | `string` | +| `params?` | `any`[] | + +#### Returns + +`Promise`<`QueryResult`\> + +#### Implementation of + +[DBAdapter](../interfaces/DBAdapter.md).[execute](../interfaces/DBAdapter.md#execute) + +#### Defined in + +[powersync-sdk-react-native/src/db/adapters/react-native-quick-sqlite/RNQSDBAdapter.ts:58](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-react-native/src/db/adapters/react-native-quick-sqlite/RNQSDBAdapter.ts#L58) + +___ + +### generateDBHelpers + +▸ **generateDBHelpers**<`T`\>(`tx`): `T` & [`DBGetUtils`](../interfaces/DBGetUtils.md) + +Adds DB get utils to lock contexts and transaction contexts + +#### Type parameters + +| Name | Type | +| :------ | :------ | +| `T` | extends `Object` | + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `tx` | `T` | + +#### Returns + +`T` & [`DBGetUtils`](../interfaces/DBGetUtils.md) + +#### Defined in + +[powersync-sdk-react-native/src/db/adapters/react-native-quick-sqlite/RNQSDBAdapter.ts:77](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-react-native/src/db/adapters/react-native-quick-sqlite/RNQSDBAdapter.ts#L77) + +___ + +### iterateListeners + +▸ **iterateListeners**(`cb`): `void` + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `cb` | (`listener`: `Partial`<[`DBAdapterListener`](../interfaces/DBAdapterListener.md)\>) => `any` | + +#### Returns + +`void` + +#### Inherited from + +[BaseObserver](BaseObserver.md).[iterateListeners](BaseObserver.md#iteratelisteners) + +#### Defined in + +powersync-sdk-common/lib/utils/BaseObserver.d.ts:13 + +___ + +### readLock + +▸ **readLock**<`T`\>(`fn`, `options?`): `Promise`<`T`\> + +#### Type parameters + +| Name | +| :------ | +| `T` | + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `fn` | (`tx`: [`LockContext`](../interfaces/LockContext.md)) => `Promise`<`T`\> | +| `options?` | [`DBLockOptions`](../interfaces/DBLockOptions.md) | + +#### Returns + +`Promise`<`T`\> + +#### Implementation of + +[DBAdapter](../interfaces/DBAdapter.md).[readLock](../interfaces/DBAdapter.md#readlock) + +#### Defined in + +[powersync-sdk-react-native/src/db/adapters/react-native-quick-sqlite/RNQSDBAdapter.ts:42](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-react-native/src/db/adapters/react-native-quick-sqlite/RNQSDBAdapter.ts#L42) + +___ + +### readOnlyExecute + +▸ **readOnlyExecute**(`sql`, `params?`): `Promise`<`QueryResult`\> + +This provides a top-level read only execute method which is executed inside a read-lock. +This is necessary since the high level `execute` method uses a write-lock under +the hood. Helper methods such as `get`, `getAll` and `getOptional` are read only, +and should use this method. + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `sql` | `string` | +| `params?` | `any`[] | + +#### Returns + +`Promise`<`QueryResult`\> + +#### Defined in + +[powersync-sdk-react-native/src/db/adapters/react-native-quick-sqlite/RNQSDBAdapter.ts:68](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-react-native/src/db/adapters/react-native-quick-sqlite/RNQSDBAdapter.ts#L68) + +___ + +### readTransaction + +▸ **readTransaction**<`T`\>(`fn`, `options?`): `Promise`<`T`\> + +#### Type parameters + +| Name | +| :------ | +| `T` | + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `fn` | (`tx`: [`Transaction`](../interfaces/Transaction.md)) => `Promise`<`T`\> | +| `options?` | [`DBLockOptions`](../interfaces/DBLockOptions.md) | + +#### Returns + +`Promise`<`T`\> + +#### Implementation of + +[DBAdapter](../interfaces/DBAdapter.md).[readTransaction](../interfaces/DBAdapter.md#readtransaction) + +#### Defined in + +[powersync-sdk-react-native/src/db/adapters/react-native-quick-sqlite/RNQSDBAdapter.ts:46](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-react-native/src/db/adapters/react-native-quick-sqlite/RNQSDBAdapter.ts#L46) + +___ + +### registerListener + +▸ **registerListener**(`listener`): () => `void` + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `listener` | `Partial`<[`DBAdapterListener`](../interfaces/DBAdapterListener.md)\> | + +#### Returns + +`fn` + +▸ (): `void` + +##### Returns + +`void` + +#### Implementation of + +[DBAdapter](../interfaces/DBAdapter.md).[registerListener](../interfaces/DBAdapter.md#registerlistener) + +#### Inherited from + +[BaseObserver](BaseObserver.md).[registerListener](BaseObserver.md#registerlistener) + +#### Defined in + +powersync-sdk-common/lib/utils/BaseObserver.d.ts:12 + +___ + +### writeLock + +▸ **writeLock**<`T`\>(`fn`, `options?`): `Promise`<`T`\> + +#### Type parameters + +| Name | +| :------ | +| `T` | + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `fn` | (`tx`: [`LockContext`](../interfaces/LockContext.md)) => `Promise`<`T`\> | +| `options?` | [`DBLockOptions`](../interfaces/DBLockOptions.md) | + +#### Returns + +`Promise`<`T`\> + +#### Implementation of + +[DBAdapter](../interfaces/DBAdapter.md).[writeLock](../interfaces/DBAdapter.md#writelock) + +#### Defined in + +[powersync-sdk-react-native/src/db/adapters/react-native-quick-sqlite/RNQSDBAdapter.ts:50](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-react-native/src/db/adapters/react-native-quick-sqlite/RNQSDBAdapter.ts#L50) + +___ + +### writeTransaction + +▸ **writeTransaction**<`T`\>(`fn`, `options?`): `Promise`<`T`\> + +#### Type parameters + +| Name | +| :------ | +| `T` | + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `fn` | (`tx`: [`Transaction`](../interfaces/Transaction.md)) => `Promise`<`T`\> | +| `options?` | [`DBLockOptions`](../interfaces/DBLockOptions.md) | + +#### Returns + +`Promise`<`T`\> + +#### Implementation of + +[DBAdapter](../interfaces/DBAdapter.md).[writeTransaction](../interfaces/DBAdapter.md#writetransaction) + +#### Defined in + +[powersync-sdk-react-native/src/db/adapters/react-native-quick-sqlite/RNQSDBAdapter.ts:54](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-react-native/src/db/adapters/react-native-quick-sqlite/RNQSDBAdapter.ts#L54) diff --git a/docs/docs/react-native-sdk/classes/RNQSPowerSyncDatabaseOpenFactory.md b/docs/docs/react-native-sdk/classes/RNQSPowerSyncDatabaseOpenFactory.md new file mode 100644 index 00000000..c7e6cc48 --- /dev/null +++ b/docs/docs/react-native-sdk/classes/RNQSPowerSyncDatabaseOpenFactory.md @@ -0,0 +1,147 @@ +--- +id: "RNQSPowerSyncDatabaseOpenFactory" +title: "Class: RNQSPowerSyncDatabaseOpenFactory" +sidebar_label: "RNQSPowerSyncDatabaseOpenFactory" +sidebar_position: 0 +custom_edit_url: null +--- + +## Hierarchy + +- [`AbstractPowerSyncDatabaseOpenFactory`](AbstractPowerSyncDatabaseOpenFactory.md) + + ↳ **`RNQSPowerSyncDatabaseOpenFactory`** + +## Constructors + +### constructor + +• **new RNQSPowerSyncDatabaseOpenFactory**(`options`): [`RNQSPowerSyncDatabaseOpenFactory`](RNQSPowerSyncDatabaseOpenFactory.md) + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `options` | [`PowerSyncOpenFactoryOptions`](../interfaces/PowerSyncOpenFactoryOptions.md) | + +#### Returns + +[`RNQSPowerSyncDatabaseOpenFactory`](RNQSPowerSyncDatabaseOpenFactory.md) + +#### Inherited from + +[AbstractPowerSyncDatabaseOpenFactory](AbstractPowerSyncDatabaseOpenFactory.md).[constructor](AbstractPowerSyncDatabaseOpenFactory.md#constructor) + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncOpenFactory.d.ts:17 + +## Properties + +### options + +• `Protected` **options**: [`PowerSyncOpenFactoryOptions`](../interfaces/PowerSyncOpenFactoryOptions.md) + +#### Inherited from + +[AbstractPowerSyncDatabaseOpenFactory](AbstractPowerSyncDatabaseOpenFactory.md).[options](AbstractPowerSyncDatabaseOpenFactory.md#options) + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncOpenFactory.d.ts:16 + +## Accessors + +### schema + +• `get` **schema**(): [`Schema`](Schema.md) + +#### Returns + +[`Schema`](Schema.md) + +#### Inherited from + +AbstractPowerSyncDatabaseOpenFactory.schema + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncOpenFactory.d.ts:18 + +## Methods + +### generateInstance + +▸ **generateInstance**(`options`): [`AbstractPowerSyncDatabase`](AbstractPowerSyncDatabase.md) + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `options` | [`PowerSyncDatabaseOptions`](../interfaces/PowerSyncDatabaseOptions.md) | + +#### Returns + +[`AbstractPowerSyncDatabase`](AbstractPowerSyncDatabase.md) + +#### Overrides + +[AbstractPowerSyncDatabaseOpenFactory](AbstractPowerSyncDatabaseOpenFactory.md).[generateInstance](AbstractPowerSyncDatabaseOpenFactory.md#generateinstance) + +#### Defined in + +[powersync-sdk-react-native/src/db/adapters/react-native-quick-sqlite/RNQSDBOpenFactory.ts:40](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-react-native/src/db/adapters/react-native-quick-sqlite/RNQSDBOpenFactory.ts#L40) + +___ + +### generateOptions + +▸ **generateOptions**(): [`PowerSyncDatabaseOptions`](../interfaces/PowerSyncDatabaseOptions.md) + +#### Returns + +[`PowerSyncDatabaseOptions`](../interfaces/PowerSyncDatabaseOptions.md) + +#### Inherited from + +[AbstractPowerSyncDatabaseOpenFactory](AbstractPowerSyncDatabaseOpenFactory.md).[generateOptions](AbstractPowerSyncDatabaseOpenFactory.md#generateoptions) + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncOpenFactory.d.ts:20 + +___ + +### getInstance + +▸ **getInstance**(): [`AbstractPowerSyncDatabase`](AbstractPowerSyncDatabase.md) + +#### Returns + +[`AbstractPowerSyncDatabase`](AbstractPowerSyncDatabase.md) + +#### Inherited from + +[AbstractPowerSyncDatabaseOpenFactory](AbstractPowerSyncDatabaseOpenFactory.md).[getInstance](AbstractPowerSyncDatabaseOpenFactory.md#getinstance) + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncOpenFactory.d.ts:22 + +___ + +### openDB + +▸ **openDB**(): [`DBAdapter`](../interfaces/DBAdapter.md) + +#### Returns + +[`DBAdapter`](../interfaces/DBAdapter.md) + +#### Overrides + +[AbstractPowerSyncDatabaseOpenFactory](AbstractPowerSyncDatabaseOpenFactory.md).[openDB](AbstractPowerSyncDatabaseOpenFactory.md#opendb) + +#### Defined in + +[powersync-sdk-react-native/src/db/adapters/react-native-quick-sqlite/RNQSDBOpenFactory.ts:13](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-react-native/src/db/adapters/react-native-quick-sqlite/RNQSDBOpenFactory.ts#L13) diff --git a/docs/docs/react-native-sdk/classes/ReactNativeRemote.md b/docs/docs/react-native-sdk/classes/ReactNativeRemote.md new file mode 100644 index 00000000..be912bbb --- /dev/null +++ b/docs/docs/react-native-sdk/classes/ReactNativeRemote.md @@ -0,0 +1,230 @@ +--- +id: "ReactNativeRemote" +title: "Class: ReactNativeRemote" +sidebar_label: "ReactNativeRemote" +sidebar_position: 0 +custom_edit_url: null +--- + +## Hierarchy + +- [`AbstractRemote`](AbstractRemote.md) + + ↳ **`ReactNativeRemote`** + +## Constructors + +### constructor + +• **new ReactNativeRemote**(`connector`, `logger?`): [`ReactNativeRemote`](ReactNativeRemote.md) + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `connector` | [`RemoteConnector`](../modules.md#remoteconnector) | +| `logger?` | `ILogger` | + +#### Returns + +[`ReactNativeRemote`](ReactNativeRemote.md) + +#### Inherited from + +[AbstractRemote](AbstractRemote.md).[constructor](AbstractRemote.md#constructor) + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/AbstractRemote.d.ts:12 + +## Properties + +### connector + +• `Protected` **connector**: [`RemoteConnector`](../modules.md#remoteconnector) + +#### Inherited from + +[AbstractRemote](AbstractRemote.md).[connector](AbstractRemote.md#connector) + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/AbstractRemote.d.ts:9 + +___ + +### credentials + +• `Protected` `Optional` **credentials**: [`PowerSyncCredentials`](../interfaces/PowerSyncCredentials.md) + +#### Inherited from + +[AbstractRemote](AbstractRemote.md).[credentials](AbstractRemote.md#credentials) + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/AbstractRemote.d.ts:11 + +___ + +### logger + +• `Protected` **logger**: `ILogger` + +#### Inherited from + +[AbstractRemote](AbstractRemote.md).[logger](AbstractRemote.md#logger) + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/AbstractRemote.d.ts:10 + +## Methods + +### get + +▸ **get**(`path`, `headers?`): `Promise`<`any`\> + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `path` | `string` | +| `headers?` | `Record`<`string`, `string`\> | + +#### Returns + +`Promise`<`any`\> + +#### Overrides + +[AbstractRemote](AbstractRemote.md).[get](AbstractRemote.md#get) + +#### Defined in + +[powersync-sdk-react-native/src/sync/stream/ReactNativeRemote.ts:25](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-react-native/src/sync/stream/ReactNativeRemote.ts#L25) + +___ + +### getCredentials + +▸ **getCredentials**(): `Promise`<[`PowerSyncCredentials`](../interfaces/PowerSyncCredentials.md)\> + +#### Returns + +`Promise`<[`PowerSyncCredentials`](../interfaces/PowerSyncCredentials.md)\> + +#### Inherited from + +[AbstractRemote](AbstractRemote.md).[getCredentials](AbstractRemote.md#getcredentials) + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/AbstractRemote.d.ts:13 + +___ + +### getHeaders + +▸ **getHeaders**(): `Promise`<\{ `Authorization`: `string` ; `content-type`: `string` }\> + +#### Returns + +`Promise`<\{ `Authorization`: `string` ; `content-type`: `string` }\> + +#### Inherited from + +[AbstractRemote](AbstractRemote.md).[getHeaders](AbstractRemote.md#getheaders) + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/AbstractRemote.d.ts:15 + +___ + +### getToken + +▸ **getToken**(): `Promise`<`string`\> + +#### Returns + +`Promise`<`string`\> + +#### Inherited from + +[AbstractRemote](AbstractRemote.md).[getToken](AbstractRemote.md#gettoken) + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/AbstractRemote.d.ts:14 + +___ + +### isAvailable + +▸ **isAvailable**(): `boolean` + +#### Returns + +`boolean` + +#### Inherited from + +[AbstractRemote](AbstractRemote.md).[isAvailable](AbstractRemote.md#isavailable) + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/AbstractRemote.d.ts:22 + +___ + +### post + +▸ **post**(`path`, `data`, `headers?`): `Promise`<`any`\> + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `path` | `string` | +| `data` | `any` | +| `headers` | `Record`<`string`, `string`\> | + +#### Returns + +`Promise`<`any`\> + +#### Overrides + +[AbstractRemote](AbstractRemote.md).[post](AbstractRemote.md#post) + +#### Defined in + +[powersync-sdk-react-native/src/sync/stream/ReactNativeRemote.ts:7](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-react-native/src/sync/stream/ReactNativeRemote.ts#L7) + +___ + +### postStreaming + +▸ **postStreaming**(`path`, `data`, `headers?`, `signal?`): `Promise`<`any`\> + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `path` | `string` | +| `data` | `any` | +| `headers` | `Record`<`string`, `string`\> | +| `signal?` | `AbortSignal` | + +#### Returns + +`Promise`<`any`\> + +#### Overrides + +[AbstractRemote](AbstractRemote.md).[postStreaming](AbstractRemote.md#poststreaming) + +#### Defined in + +[powersync-sdk-react-native/src/sync/stream/ReactNativeRemote.ts:43](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-react-native/src/sync/stream/ReactNativeRemote.ts#L43) diff --git a/docs/docs/react-native-sdk/classes/ReactNativeStreamingSyncImplementation.md b/docs/docs/react-native-sdk/classes/ReactNativeStreamingSyncImplementation.md new file mode 100644 index 00000000..61fc8981 --- /dev/null +++ b/docs/docs/react-native-sdk/classes/ReactNativeStreamingSyncImplementation.md @@ -0,0 +1,409 @@ +--- +id: "ReactNativeStreamingSyncImplementation" +title: "Class: ReactNativeStreamingSyncImplementation" +sidebar_label: "ReactNativeStreamingSyncImplementation" +sidebar_position: 0 +custom_edit_url: null +--- + +## Hierarchy + +- [`AbstractStreamingSyncImplementation`](AbstractStreamingSyncImplementation.md) + + ↳ **`ReactNativeStreamingSyncImplementation`** + +## Constructors + +### constructor + +• **new ReactNativeStreamingSyncImplementation**(`options`): [`ReactNativeStreamingSyncImplementation`](ReactNativeStreamingSyncImplementation.md) + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `options` | [`AbstractStreamingSyncImplementationOptions`](../interfaces/AbstractStreamingSyncImplementationOptions.md) | + +#### Returns + +[`ReactNativeStreamingSyncImplementation`](ReactNativeStreamingSyncImplementation.md) + +#### Overrides + +[AbstractStreamingSyncImplementation](AbstractStreamingSyncImplementation.md).[constructor](AbstractStreamingSyncImplementation.md#constructor) + +#### Defined in + +[powersync-sdk-react-native/src/sync/stream/ReactNativeStreamingSyncImplementation.ts:11](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-react-native/src/sync/stream/ReactNativeStreamingSyncImplementation.ts#L11) + +## Properties + +### \_isConnected + +• `Protected` **\_isConnected**: `boolean` + +#### Inherited from + +[AbstractStreamingSyncImplementation](AbstractStreamingSyncImplementation.md).[_isConnected](AbstractStreamingSyncImplementation.md#_isconnected) + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/AbstractStreamingSyncImplementation.d.ts:38 + +___ + +### \_lastSyncedAt + +• `Protected` **\_lastSyncedAt**: `Date` + +#### Inherited from + +[AbstractStreamingSyncImplementation](AbstractStreamingSyncImplementation.md).[_lastSyncedAt](AbstractStreamingSyncImplementation.md#_lastsyncedat) + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/AbstractStreamingSyncImplementation.d.ts:35 + +___ + +### listeners + +• `Protected` **listeners**: `Object` + +#### Index signature + +▪ [id: `string`]: `Partial`<`T`\> + +#### Inherited from + +[AbstractStreamingSyncImplementation](AbstractStreamingSyncImplementation.md).[listeners](AbstractStreamingSyncImplementation.md#listeners) + +#### Defined in + +powersync-sdk-common/lib/utils/BaseObserver.d.ts:8 + +___ + +### locks + +• **locks**: `Map`<[`LockType`](../enums/LockType.md), `AsyncLock`\> + +#### Defined in + +[powersync-sdk-react-native/src/sync/stream/ReactNativeStreamingSyncImplementation.ts:9](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-react-native/src/sync/stream/ReactNativeStreamingSyncImplementation.ts#L9) + +___ + +### options + +• `Protected` **options**: [`AbstractStreamingSyncImplementationOptions`](../interfaces/AbstractStreamingSyncImplementationOptions.md) + +#### Inherited from + +[AbstractStreamingSyncImplementation](AbstractStreamingSyncImplementation.md).[options](AbstractStreamingSyncImplementation.md#options) + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/AbstractStreamingSyncImplementation.d.ts:36 + +## Accessors + +### isConnected + +• `get` **isConnected**(): `boolean` + +#### Returns + +`boolean` + +#### Inherited from + +AbstractStreamingSyncImplementation.isConnected + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/AbstractStreamingSyncImplementation.d.ts:42 + +___ + +### lastSyncedAt + +• `get` **lastSyncedAt**(): `Date` + +#### Returns + +`Date` + +#### Inherited from + +AbstractStreamingSyncImplementation.lastSyncedAt + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/AbstractStreamingSyncImplementation.d.ts:40 + +___ + +### logger + +• `get` **logger**(): `ILogger` + +#### Returns + +`ILogger` + +#### Inherited from + +AbstractStreamingSyncImplementation.logger + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/AbstractStreamingSyncImplementation.d.ts:41 + +## Methods + +### \_uploadAllCrud + +▸ **_uploadAllCrud**(): `Promise`<`void`\> + +#### Returns + +`Promise`<`void`\> + +#### Inherited from + +[AbstractStreamingSyncImplementation](AbstractStreamingSyncImplementation.md).[_uploadAllCrud](AbstractStreamingSyncImplementation.md#_uploadallcrud) + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/AbstractStreamingSyncImplementation.d.ts:46 + +___ + +### getWriteCheckpoint + +▸ **getWriteCheckpoint**(): `Promise`<`string`\> + +#### Returns + +`Promise`<`string`\> + +#### Inherited from + +[AbstractStreamingSyncImplementation](AbstractStreamingSyncImplementation.md).[getWriteCheckpoint](AbstractStreamingSyncImplementation.md#getwritecheckpoint) + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/AbstractStreamingSyncImplementation.d.ts:48 + +___ + +### hasCompletedSync + +▸ **hasCompletedSync**(): `Promise`<`boolean`\> + +#### Returns + +`Promise`<`boolean`\> + +#### Inherited from + +[AbstractStreamingSyncImplementation](AbstractStreamingSyncImplementation.md).[hasCompletedSync](AbstractStreamingSyncImplementation.md#hascompletedsync) + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/AbstractStreamingSyncImplementation.d.ts:44 + +___ + +### iterateListeners + +▸ **iterateListeners**(`cb`): `void` + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `cb` | (`listener`: `Partial`<[`StreamingSyncImplementationListener`](../interfaces/StreamingSyncImplementationListener.md)\>) => `any` | + +#### Returns + +`void` + +#### Inherited from + +[AbstractStreamingSyncImplementation](AbstractStreamingSyncImplementation.md).[iterateListeners](AbstractStreamingSyncImplementation.md#iteratelisteners) + +#### Defined in + +powersync-sdk-common/lib/utils/BaseObserver.d.ts:13 + +___ + +### obtainLock + +▸ **obtainLock**<`T`\>(`lockOptions`): `Promise`<`T`\> + +#### Type parameters + +| Name | +| :------ | +| `T` | + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `lockOptions` | [`LockOptions`](../interfaces/LockOptions.md)<`T`\> | + +#### Returns + +`Promise`<`T`\> + +#### Overrides + +[AbstractStreamingSyncImplementation](AbstractStreamingSyncImplementation.md).[obtainLock](AbstractStreamingSyncImplementation.md#obtainlock) + +#### Defined in + +[powersync-sdk-react-native/src/sync/stream/ReactNativeStreamingSyncImplementation.ts:18](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-react-native/src/sync/stream/ReactNativeStreamingSyncImplementation.ts#L18) + +___ + +### registerListener + +▸ **registerListener**(`listener`): () => `void` + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `listener` | `Partial`<[`StreamingSyncImplementationListener`](../interfaces/StreamingSyncImplementationListener.md)\> | + +#### Returns + +`fn` + +▸ (): `void` + +##### Returns + +`void` + +#### Inherited from + +[AbstractStreamingSyncImplementation](AbstractStreamingSyncImplementation.md).[registerListener](AbstractStreamingSyncImplementation.md#registerlistener) + +#### Defined in + +powersync-sdk-common/lib/utils/BaseObserver.d.ts:12 + +___ + +### streamingSync + +▸ **streamingSync**(`signal?`): `Promise`<`void`\> + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `signal?` | `AbortSignal` | + +#### Returns + +`Promise`<`void`\> + +#### Inherited from + +[AbstractStreamingSyncImplementation](AbstractStreamingSyncImplementation.md).[streamingSync](AbstractStreamingSyncImplementation.md#streamingsync) + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/AbstractStreamingSyncImplementation.d.ts:49 + +___ + +### streamingSyncIteration + +▸ **streamingSyncIteration**(`signal?`, `progress?`): `Promise`<\{ `retry?`: `boolean` }\> + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `signal?` | `AbortSignal` | +| `progress?` | () => `void` | + +#### Returns + +`Promise`<\{ `retry?`: `boolean` }\> + +#### Inherited from + +[AbstractStreamingSyncImplementation](AbstractStreamingSyncImplementation.md).[streamingSyncIteration](AbstractStreamingSyncImplementation.md#streamingsynciteration) + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/AbstractStreamingSyncImplementation.d.ts:50 + +___ + +### streamingSyncRequest + +▸ **streamingSyncRequest**(`req`, `signal`): `AsyncGenerator`<[`StreamingSyncLine`](../modules.md#streamingsyncline), `any`, `unknown`\> + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `req` | [`StreamingSyncRequest`](../interfaces/StreamingSyncRequest.md) | +| `signal` | `AbortSignal` | + +#### Returns + +`AsyncGenerator`<[`StreamingSyncLine`](../modules.md#streamingsyncline), `any`, `unknown`\> + +#### Inherited from + +[AbstractStreamingSyncImplementation](AbstractStreamingSyncImplementation.md).[streamingSyncRequest](AbstractStreamingSyncImplementation.md#streamingsyncrequest) + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/AbstractStreamingSyncImplementation.d.ts:53 + +___ + +### triggerCrudUpload + +▸ **triggerCrudUpload**(): `void` + +#### Returns + +`void` + +#### Inherited from + +[AbstractStreamingSyncImplementation](AbstractStreamingSyncImplementation.md).[triggerCrudUpload](AbstractStreamingSyncImplementation.md#triggercrudupload) + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/AbstractStreamingSyncImplementation.d.ts:45 + +___ + +### uploadCrudBatch + +▸ **uploadCrudBatch**(): `Promise`<`boolean`\> + +#### Returns + +`Promise`<`boolean`\> + +#### Inherited from + +[AbstractStreamingSyncImplementation](AbstractStreamingSyncImplementation.md).[uploadCrudBatch](AbstractStreamingSyncImplementation.md#uploadcrudbatch) + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/AbstractStreamingSyncImplementation.d.ts:47 diff --git a/docs/docs/react-native-sdk/classes/Schema.md b/docs/docs/react-native-sdk/classes/Schema.md new file mode 100644 index 00000000..bb26b7ba --- /dev/null +++ b/docs/docs/react-native-sdk/classes/Schema.md @@ -0,0 +1,55 @@ +--- +id: "Schema" +title: "Class: Schema" +sidebar_label: "Schema" +sidebar_position: 0 +custom_edit_url: null +--- + +## Constructors + +### constructor + +• **new Schema**(`tables`): [`Schema`](Schema.md) + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `tables` | [`Table`](Table.md)[] | + +#### Returns + +[`Schema`](Schema.md) + +#### Defined in + +powersync-sdk-common/lib/db/schema/Schema.d.ts:4 + +## Properties + +### tables + +• **tables**: [`Table`](Table.md)[] + +#### Defined in + +powersync-sdk-common/lib/db/schema/Schema.d.ts:3 + +## Methods + +### toJSON + +▸ **toJSON**(): `Object` + +#### Returns + +`Object` + +| Name | Type | +| :------ | :------ | +| `tables` | \{ `columns`: \{ `name`: `string` ; `type`: [`ColumnType`](../enums/ColumnType.md) }[] ; `indexes`: \{ `columns`: \{ `ascending`: `boolean` ; `name`: `string` ; `type`: [`ColumnType`](../enums/ColumnType.md) }[] ; `name`: `string` }[] ; `insert_only`: `boolean` ; `local_only`: `boolean` ; `name`: `string` }[] | + +#### Defined in + +powersync-sdk-common/lib/db/schema/Schema.d.ts:5 diff --git a/docs/docs/react-native-sdk/classes/SqliteBucketStorage.md b/docs/docs/react-native-sdk/classes/SqliteBucketStorage.md new file mode 100644 index 00000000..8e72e159 --- /dev/null +++ b/docs/docs/react-native-sdk/classes/SqliteBucketStorage.md @@ -0,0 +1,510 @@ +--- +id: "SqliteBucketStorage" +title: "Class: SqliteBucketStorage" +sidebar_label: "SqliteBucketStorage" +sidebar_position: 0 +custom_edit_url: null +--- + +## Implements + +- [`BucketStorageAdapter`](../interfaces/BucketStorageAdapter.md) + +## Constructors + +### constructor + +• **new SqliteBucketStorage**(`db`, `mutex`, `logger?`): [`SqliteBucketStorage`](SqliteBucketStorage.md) + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `db` | [`DBAdapter`](../interfaces/DBAdapter.md) | +| `mutex` | `Mutex` | +| `logger?` | `ILogger` | + +#### Returns + +[`SqliteBucketStorage`](SqliteBucketStorage.md) + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/SqliteBucketStorage.d.ts:19 + +## Properties + +### \_hasCompletedSync + +• `Private` **\_hasCompletedSync**: `any` + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/SqliteBucketStorage.d.ts:14 + +___ + +### clearRemoveOps + +• `Private` **clearRemoveOps**: `any` + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/SqliteBucketStorage.d.ts:50 + +___ + +### compactCounter + +• `Private` **compactCounter**: `any` + +Count up, and do a compact on startup. + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/SqliteBucketStorage.d.ts:18 + +___ + +### db + +• `Private` **db**: `any` + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/SqliteBucketStorage.d.ts:8 + +___ + +### deleteBucket + +• `Private` **deleteBucket**: `any` + +Mark a bucket for deletion. + +**`Param`** + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/SqliteBucketStorage.d.ts:34 + +___ + +### deletePendingBuckets + +• `Private` **deletePendingBuckets**: `any` + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/SqliteBucketStorage.d.ts:49 + +___ + +### logger + +• `Private` **logger**: `any` + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/SqliteBucketStorage.d.ts:10 + +___ + +### mutex + +• `Private` **mutex**: `any` + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/SqliteBucketStorage.d.ts:9 + +___ + +### pendingBucketDeletes + +• `Private` **pendingBucketDeletes**: `any` + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/SqliteBucketStorage.d.ts:13 + +___ + +### tableNames + +• **tableNames**: `Set`<`string`\> + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/SqliteBucketStorage.d.ts:12 + +___ + +### updateObjectsFromBuckets + +• `Private` **updateObjectsFromBuckets**: `any` + +Atomically update the local state to the current checkpoint. + +This includes creating new tables, dropping old tables, and copying data over from the oplog. + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/SqliteBucketStorage.d.ts:42 + +___ + +### MAX\_OP\_ID + +▪ `Static` **MAX\_OP\_ID**: `string` + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/SqliteBucketStorage.d.ts:11 + +## Methods + +### autoCompact + +▸ **autoCompact**(): `Promise`<`void`\> + +Exposed for tests only. + +#### Returns + +`Promise`<`void`\> + +#### Implementation of + +[BucketStorageAdapter](../interfaces/BucketStorageAdapter.md).[autoCompact](../interfaces/BucketStorageAdapter.md#autocompact) + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/SqliteBucketStorage.d.ts:48 + +___ + +### forceCompact + +▸ **forceCompact**(): `Promise`<`void`\> + +Force a compact, for tests. + +#### Returns + +`Promise`<`void`\> + +#### Implementation of + +[BucketStorageAdapter](../interfaces/BucketStorageAdapter.md).[forceCompact](../interfaces/BucketStorageAdapter.md#forcecompact) + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/SqliteBucketStorage.d.ts:47 + +___ + +### getBucketStates + +▸ **getBucketStates**(): `Promise`<[`BucketState`](../interfaces/BucketState.md)[]\> + +#### Returns + +`Promise`<[`BucketState`](../interfaces/BucketState.md)[]\> + +#### Implementation of + +[BucketStorageAdapter](../interfaces/BucketStorageAdapter.md).[getBucketStates](../interfaces/BucketStorageAdapter.md#getbucketstates) + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/SqliteBucketStorage.d.ts:26 + +___ + +### getCrudBatch + +▸ **getCrudBatch**(`limit?`): `Promise`<[`CrudBatch`](CrudBatch.md)\> + +Get a batch of objects to send to the server. +When the objects are successfully sent to the server, call .complete() + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `limit?` | `number` | + +#### Returns + +`Promise`<[`CrudBatch`](CrudBatch.md)\> + +#### Implementation of + +[BucketStorageAdapter](../interfaces/BucketStorageAdapter.md).[getCrudBatch](../interfaces/BucketStorageAdapter.md#getcrudbatch) + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/SqliteBucketStorage.d.ts:57 + +___ + +### getMaxOpId + +▸ **getMaxOpId**(): `string` + +#### Returns + +`string` + +#### Implementation of + +[BucketStorageAdapter](../interfaces/BucketStorageAdapter.md).[getMaxOpId](../interfaces/BucketStorageAdapter.md#getmaxopid) + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/SqliteBucketStorage.d.ts:21 + +___ + +### hasCompletedSync + +▸ **hasCompletedSync**(): `Promise`<`boolean`\> + +#### Returns + +`Promise`<`boolean`\> + +#### Implementation of + +[BucketStorageAdapter](../interfaces/BucketStorageAdapter.md).[hasCompletedSync](../interfaces/BucketStorageAdapter.md#hascompletedsync) + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/SqliteBucketStorage.d.ts:35 + +___ + +### hasCrud + +▸ **hasCrud**(): `Promise`<`boolean`\> + +#### Returns + +`Promise`<`boolean`\> + +#### Implementation of + +[BucketStorageAdapter](../interfaces/BucketStorageAdapter.md).[hasCrud](../interfaces/BucketStorageAdapter.md#hascrud) + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/SqliteBucketStorage.d.ts:52 + +___ + +### init + +▸ **init**(): `Promise`<`void`\> + +#### Returns + +`Promise`<`void`\> + +#### Implementation of + +[BucketStorageAdapter](../interfaces/BucketStorageAdapter.md).[init](../interfaces/BucketStorageAdapter.md#init) + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/SqliteBucketStorage.d.ts:20 + +___ + +### removeBuckets + +▸ **removeBuckets**(`buckets`): `Promise`<`void`\> + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `buckets` | `string`[] | + +#### Returns + +`Promise`<`void`\> + +#### Implementation of + +[BucketStorageAdapter](../interfaces/BucketStorageAdapter.md).[removeBuckets](../interfaces/BucketStorageAdapter.md#removebuckets) + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/SqliteBucketStorage.d.ts:28 + +___ + +### saveSyncData + +▸ **saveSyncData**(`batch`): `Promise`<`void`\> + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `batch` | [`SyncDataBatch`](SyncDataBatch.md) | + +#### Returns + +`Promise`<`void`\> + +#### Implementation of + +[BucketStorageAdapter](../interfaces/BucketStorageAdapter.md).[saveSyncData](../interfaces/BucketStorageAdapter.md#savesyncdata) + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/SqliteBucketStorage.d.ts:27 + +___ + +### setTargetCheckpoint + +▸ **setTargetCheckpoint**(`checkpoint`): `Promise`<`void`\> + +Set a target checkpoint. + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `checkpoint` | [`Checkpoint`](../interfaces/Checkpoint.md) | + +#### Returns + +`Promise`<`void`\> + +#### Implementation of + +[BucketStorageAdapter](../interfaces/BucketStorageAdapter.md).[setTargetCheckpoint](../interfaces/BucketStorageAdapter.md#settargetcheckpoint) + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/SqliteBucketStorage.d.ts:64 + +___ + +### startSession + +▸ **startSession**(): `void` + +Reset any caches. + +#### Returns + +`void` + +#### Implementation of + +[BucketStorageAdapter](../interfaces/BucketStorageAdapter.md).[startSession](../interfaces/BucketStorageAdapter.md#startsession) + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/SqliteBucketStorage.d.ts:25 + +___ + +### syncLocalDatabase + +▸ **syncLocalDatabase**(`checkpoint`): `Promise`<[`SyncLocalDatabaseResult`](../interfaces/SyncLocalDatabaseResult.md)\> + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `checkpoint` | [`Checkpoint`](../interfaces/Checkpoint.md) | + +#### Returns + +`Promise`<[`SyncLocalDatabaseResult`](../interfaces/SyncLocalDatabaseResult.md)\> + +#### Implementation of + +[BucketStorageAdapter](../interfaces/BucketStorageAdapter.md).[syncLocalDatabase](../interfaces/BucketStorageAdapter.md#synclocaldatabase) + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/SqliteBucketStorage.d.ts:36 + +___ + +### updateLocalTarget + +▸ **updateLocalTarget**(`cb`): `Promise`<`boolean`\> + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `cb` | () => `Promise`<`string`\> | + +#### Returns + +`Promise`<`boolean`\> + +#### Implementation of + +[BucketStorageAdapter](../interfaces/BucketStorageAdapter.md).[updateLocalTarget](../interfaces/BucketStorageAdapter.md#updatelocaltarget) + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/SqliteBucketStorage.d.ts:51 + +___ + +### validateChecksums + +▸ **validateChecksums**(`checkpoint`): `Promise`<[`SyncLocalDatabaseResult`](../interfaces/SyncLocalDatabaseResult.md)\> + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `checkpoint` | [`Checkpoint`](../interfaces/Checkpoint.md) | + +#### Returns + +`Promise`<[`SyncLocalDatabaseResult`](../interfaces/SyncLocalDatabaseResult.md)\> + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/SqliteBucketStorage.d.ts:43 + +___ + +### writeTransaction + +▸ **writeTransaction**<`T`\>(`callback`, `options?`): `Promise`<`T`\> + +#### Type parameters + +| Name | +| :------ | +| `T` | + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `callback` | (`tx`: [`Transaction`](../interfaces/Transaction.md)) => `Promise`<`T`\> | +| `options?` | `Object` | +| `options.timeoutMs` | `number` | + +#### Returns + +`Promise`<`T`\> + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/SqliteBucketStorage.d.ts:58 diff --git a/docs/docs/react-native-sdk/classes/SyncDataBatch.md b/docs/docs/react-native-sdk/classes/SyncDataBatch.md new file mode 100644 index 00000000..e5890652 --- /dev/null +++ b/docs/docs/react-native-sdk/classes/SyncDataBatch.md @@ -0,0 +1,57 @@ +--- +id: "SyncDataBatch" +title: "Class: SyncDataBatch" +sidebar_label: "SyncDataBatch" +sidebar_position: 0 +custom_edit_url: null +--- + +## Constructors + +### constructor + +• **new SyncDataBatch**(`buckets`): [`SyncDataBatch`](SyncDataBatch.md) + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `buckets` | [`SyncDataBucket`](SyncDataBucket.md)[] | + +#### Returns + +[`SyncDataBatch`](SyncDataBatch.md) + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/SyncDataBatch.d.ts:5 + +## Properties + +### buckets + +• **buckets**: [`SyncDataBucket`](SyncDataBucket.md)[] + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/SyncDataBatch.d.ts:3 + +## Methods + +### fromJSON + +▸ **fromJSON**(`json`): [`SyncDataBatch`](SyncDataBatch.md) + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `json` | `any` | + +#### Returns + +[`SyncDataBatch`](SyncDataBatch.md) + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/SyncDataBatch.d.ts:4 diff --git a/docs/docs/react-native-sdk/classes/SyncDataBucket.md b/docs/docs/react-native-sdk/classes/SyncDataBucket.md new file mode 100644 index 00000000..a079b493 --- /dev/null +++ b/docs/docs/react-native-sdk/classes/SyncDataBucket.md @@ -0,0 +1,121 @@ +--- +id: "SyncDataBucket" +title: "Class: SyncDataBucket" +sidebar_label: "SyncDataBucket" +sidebar_position: 0 +custom_edit_url: null +--- + +## Constructors + +### constructor + +• **new SyncDataBucket**(`bucket`, `data`, `has_more`, `after`, `next_after`): [`SyncDataBucket`](SyncDataBucket.md) + +#### Parameters + +| Name | Type | Description | +| :------ | :------ | :------ | +| `bucket` | `string` | - | +| `data` | `OplogEntry`[] | - | +| `has_more` | `boolean` | True if the response does not contain all the data for this bucket, and another request must be made. | +| `after` | `string` | The `after` specified in the request. | +| `next_after` | `string` | Use this for the next request. | + +#### Returns + +[`SyncDataBucket`](SyncDataBucket.md) + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/SyncDataBucket.d.ts:27 + +## Properties + +### after + +• **after**: `string` + +The `after` specified in the request. + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/SyncDataBucket.d.ts:21 + +___ + +### bucket + +• **bucket**: `string` + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/SyncDataBucket.d.ts:12 + +___ + +### data + +• **data**: `OplogEntry`[] + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/SyncDataBucket.d.ts:13 + +___ + +### has\_more + +• **has\_more**: `boolean` + +True if the response does not contain all the data for this bucket, and another request must be made. + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/SyncDataBucket.d.ts:17 + +___ + +### next\_after + +• **next\_after**: `string` + +Use this for the next request. + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/SyncDataBucket.d.ts:25 + +## Methods + +### toJSON + +▸ **toJSON**(): [`SyncDataBucketJSON`](../modules.md#syncdatabucketjson) + +#### Returns + +[`SyncDataBucketJSON`](../modules.md#syncdatabucketjson) + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/SyncDataBucket.d.ts:40 + +___ + +### fromRow + +▸ **fromRow**(`row`): [`SyncDataBucket`](SyncDataBucket.md) + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `row` | [`SyncDataBucketJSON`](../modules.md#syncdatabucketjson) | + +#### Returns + +[`SyncDataBucket`](SyncDataBucket.md) + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/SyncDataBucket.d.ts:26 diff --git a/docs/docs/react-native-sdk/classes/SyncStatus.md b/docs/docs/react-native-sdk/classes/SyncStatus.md new file mode 100644 index 00000000..3561c1d1 --- /dev/null +++ b/docs/docs/react-native-sdk/classes/SyncStatus.md @@ -0,0 +1,62 @@ +--- +id: "SyncStatus" +title: "Class: SyncStatus" +sidebar_label: "SyncStatus" +sidebar_position: 0 +custom_edit_url: null +--- + +## Constructors + +### constructor + +• **new SyncStatus**(`connected`, `lastSyncedAt`): [`SyncStatus`](SyncStatus.md) + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `connected` | `boolean` | +| `lastSyncedAt` | `Date` | + +#### Returns + +[`SyncStatus`](SyncStatus.md) + +#### Defined in + +powersync-sdk-common/lib/db/crud/SyncStatus.d.ts:4 + +## Properties + +### connected + +• **connected**: `boolean` + +#### Defined in + +powersync-sdk-common/lib/db/crud/SyncStatus.d.ts:2 + +___ + +### lastSyncedAt + +• **lastSyncedAt**: `Date` + +#### Defined in + +powersync-sdk-common/lib/db/crud/SyncStatus.d.ts:3 + +## Methods + +### getMessage + +▸ **getMessage**(): `string` + +#### Returns + +`string` + +#### Defined in + +powersync-sdk-common/lib/db/crud/SyncStatus.d.ts:5 diff --git a/docs/docs/react-native-sdk/classes/Table.md b/docs/docs/react-native-sdk/classes/Table.md new file mode 100644 index 00000000..0f0b6eeb --- /dev/null +++ b/docs/docs/react-native-sdk/classes/Table.md @@ -0,0 +1,197 @@ +--- +id: "Table" +title: "Class: Table" +sidebar_label: "Table" +sidebar_position: 0 +custom_edit_url: null +--- + +## Constructors + +### constructor + +• **new Table**(`options`): [`Table`](Table.md) + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `options` | [`TableOptions`](../interfaces/TableOptions.md) | + +#### Returns + +[`Table`](Table.md) + +#### Defined in + +powersync-sdk-common/lib/db/schema/Table.d.ts:15 + +## Properties + +### options + +• `Protected` **options**: [`TableOptions`](../interfaces/TableOptions.md) + +#### Defined in + +powersync-sdk-common/lib/db/schema/Table.d.ts:12 + +## Accessors + +### columns + +• `get` **columns**(): [`Column`](Column.md)[] + +#### Returns + +[`Column`](Column.md)[] + +#### Defined in + +powersync-sdk-common/lib/db/schema/Table.d.ts:17 + +___ + +### indexes + +• `get` **indexes**(): [`Index`](Index.md)[] + +#### Returns + +[`Index`](Index.md)[] + +#### Defined in + +powersync-sdk-common/lib/db/schema/Table.d.ts:18 + +___ + +### insertOnly + +• `get` **insertOnly**(): `boolean` + +#### Returns + +`boolean` + +#### Defined in + +powersync-sdk-common/lib/db/schema/Table.d.ts:20 + +___ + +### internalName + +• `get` **internalName**(): `string` + +#### Returns + +`string` + +#### Defined in + +powersync-sdk-common/lib/db/schema/Table.d.ts:21 + +___ + +### localOnly + +• `get` **localOnly**(): `boolean` + +#### Returns + +`boolean` + +#### Defined in + +powersync-sdk-common/lib/db/schema/Table.d.ts:19 + +___ + +### name + +• `get` **name**(): `string` + +#### Returns + +`string` + +#### Defined in + +powersync-sdk-common/lib/db/schema/Table.d.ts:16 + +___ + +### validName + +• `get` **validName**(): `boolean` + +#### Returns + +`boolean` + +#### Defined in + +powersync-sdk-common/lib/db/schema/Table.d.ts:22 + +## Methods + +### toJSON + +▸ **toJSON**(): `Object` + +#### Returns + +`Object` + +| Name | Type | +| :------ | :------ | +| `columns` | \{ `name`: `string` ; `type`: [`ColumnType`](../enums/ColumnType.md) }[] | +| `indexes` | \{ `columns`: \{ `ascending`: `boolean` ; `name`: `string` ; `type`: [`ColumnType`](../enums/ColumnType.md) }[] ; `name`: `string` }[] | +| `insert_only` | `boolean` | +| `local_only` | `boolean` | +| `name` | `string` | + +#### Defined in + +powersync-sdk-common/lib/db/schema/Table.d.ts:23 + +___ + +### createInsertOnly + +▸ **createInsertOnly**(`options`): [`Table`](Table.md) + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `options` | [`TableOptions`](../interfaces/TableOptions.md) | + +#### Returns + +[`Table`](Table.md) + +#### Defined in + +powersync-sdk-common/lib/db/schema/Table.d.ts:14 + +___ + +### createLocalOnly + +▸ **createLocalOnly**(`options`): [`Table`](Table.md) + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `options` | [`TableOptions`](../interfaces/TableOptions.md) | + +#### Returns + +[`Table`](Table.md) + +#### Defined in + +powersync-sdk-common/lib/db/schema/Table.d.ts:13 diff --git a/docs/docs/react-native-sdk/classes/UploadQueueStats.md b/docs/docs/react-native-sdk/classes/UploadQueueStats.md new file mode 100644 index 00000000..9a463588 --- /dev/null +++ b/docs/docs/react-native-sdk/classes/UploadQueueStats.md @@ -0,0 +1,62 @@ +--- +id: "UploadQueueStats" +title: "Class: UploadQueueStats" +sidebar_label: "UploadQueueStats" +sidebar_position: 0 +custom_edit_url: null +--- + +## Constructors + +### constructor + +• **new UploadQueueStats**(`count`, `size?`): [`UploadQueueStats`](UploadQueueStats.md) + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `count` | `number` | +| `size?` | `number` | + +#### Returns + +[`UploadQueueStats`](UploadQueueStats.md) + +#### Defined in + +powersync-sdk-common/lib/db/crud/UploadQueueStatus.d.ts:4 + +## Properties + +### count + +• **count**: `number` + +#### Defined in + +powersync-sdk-common/lib/db/crud/UploadQueueStatus.d.ts:2 + +___ + +### size + +• **size**: `number` + +#### Defined in + +powersync-sdk-common/lib/db/crud/UploadQueueStatus.d.ts:3 + +## Methods + +### toString + +▸ **toString**(): `string` + +#### Returns + +`string` + +#### Defined in + +powersync-sdk-common/lib/db/crud/UploadQueueStatus.d.ts:5 diff --git a/docs/docs/react-native-sdk/classes/_category_.yml b/docs/docs/react-native-sdk/classes/_category_.yml new file mode 100644 index 00000000..55c7980a --- /dev/null +++ b/docs/docs/react-native-sdk/classes/_category_.yml @@ -0,0 +1,2 @@ +label: "Classes" +position: 3 \ No newline at end of file diff --git a/docs/docs/react-native-sdk/enums/ColumnType.md b/docs/docs/react-native-sdk/enums/ColumnType.md new file mode 100644 index 00000000..219a58d1 --- /dev/null +++ b/docs/docs/react-native-sdk/enums/ColumnType.md @@ -0,0 +1,37 @@ +--- +id: "ColumnType" +title: "Enumeration: ColumnType" +sidebar_label: "ColumnType" +sidebar_position: 0 +custom_edit_url: null +--- + +## Enumeration Members + +### INTEGER + +• **INTEGER** = ``"INTEGER"`` + +#### Defined in + +powersync-sdk-common/lib/db/Column.d.ts:3 + +___ + +### REAL + +• **REAL** = ``"REAL"`` + +#### Defined in + +powersync-sdk-common/lib/db/Column.d.ts:4 + +___ + +### TEXT + +• **TEXT** = ``"TEXT"`` + +#### Defined in + +powersync-sdk-common/lib/db/Column.d.ts:2 diff --git a/docs/docs/react-native-sdk/enums/LockType.md b/docs/docs/react-native-sdk/enums/LockType.md new file mode 100644 index 00000000..d32042e1 --- /dev/null +++ b/docs/docs/react-native-sdk/enums/LockType.md @@ -0,0 +1,27 @@ +--- +id: "LockType" +title: "Enumeration: LockType" +sidebar_label: "LockType" +sidebar_position: 0 +custom_edit_url: null +--- + +## Enumeration Members + +### CRUD + +• **CRUD** = ``"crud"`` + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/AbstractStreamingSyncImplementation.d.ts:9 + +___ + +### SYNC + +• **SYNC** = ``"sync"`` + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/AbstractStreamingSyncImplementation.d.ts:10 diff --git a/docs/docs/react-native-sdk/enums/OpTypeEnum.md b/docs/docs/react-native-sdk/enums/OpTypeEnum.md new file mode 100644 index 00000000..24ca43f1 --- /dev/null +++ b/docs/docs/react-native-sdk/enums/OpTypeEnum.md @@ -0,0 +1,47 @@ +--- +id: "OpTypeEnum" +title: "Enumeration: OpTypeEnum" +sidebar_label: "OpTypeEnum" +sidebar_position: 0 +custom_edit_url: null +--- + +## Enumeration Members + +### CLEAR + +• **CLEAR** = ``1`` + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/OpType.d.ts:2 + +___ + +### MOVE + +• **MOVE** = ``2`` + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/OpType.d.ts:3 + +___ + +### PUT + +• **PUT** = ``3`` + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/OpType.d.ts:4 + +___ + +### REMOVE + +• **REMOVE** = ``4`` + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/OpType.d.ts:5 diff --git a/docs/docs/react-native-sdk/enums/RowUpdateType.md b/docs/docs/react-native-sdk/enums/RowUpdateType.md new file mode 100644 index 00000000..ffd68b59 --- /dev/null +++ b/docs/docs/react-native-sdk/enums/RowUpdateType.md @@ -0,0 +1,39 @@ +--- +id: "RowUpdateType" +title: "Enumeration: RowUpdateType" +sidebar_label: "RowUpdateType" +sidebar_position: 0 +custom_edit_url: null +--- + +Update table operation numbers from SQLite + +## Enumeration Members + +### SQLITE\_DELETE + +• **SQLITE\_DELETE** = ``9`` + +#### Defined in + +powersync-sdk-common/lib/db/DBAdapter.d.ts:48 + +___ + +### SQLITE\_INSERT + +• **SQLITE\_INSERT** = ``18`` + +#### Defined in + +powersync-sdk-common/lib/db/DBAdapter.d.ts:47 + +___ + +### SQLITE\_UPDATE + +• **SQLITE\_UPDATE** = ``23`` + +#### Defined in + +powersync-sdk-common/lib/db/DBAdapter.d.ts:49 diff --git a/docs/docs/react-native-sdk/enums/UpdateType.md b/docs/docs/react-native-sdk/enums/UpdateType.md new file mode 100644 index 00000000..6649856a --- /dev/null +++ b/docs/docs/react-native-sdk/enums/UpdateType.md @@ -0,0 +1,37 @@ +--- +id: "UpdateType" +title: "Enumeration: UpdateType" +sidebar_label: "UpdateType" +sidebar_position: 0 +custom_edit_url: null +--- + +## Enumeration Members + +### DELETE + +• **DELETE** = ``"DELETE"`` + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/CrudEntry.d.ts:10 + +___ + +### PATCH + +• **PATCH** = ``"PATCH"`` + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/CrudEntry.d.ts:9 + +___ + +### PUT + +• **PUT** = ``"PUT"`` + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/CrudEntry.d.ts:8 diff --git a/docs/docs/react-native-sdk/enums/_category_.yml b/docs/docs/react-native-sdk/enums/_category_.yml new file mode 100644 index 00000000..1687a9e0 --- /dev/null +++ b/docs/docs/react-native-sdk/enums/_category_.yml @@ -0,0 +1,2 @@ +label: "Enumerations" +position: 2 \ No newline at end of file diff --git a/docs/docs/react-native-sdk/index.md b/docs/docs/react-native-sdk/index.md new file mode 100644 index 00000000..2bec3db8 --- /dev/null +++ b/docs/docs/react-native-sdk/index.md @@ -0,0 +1,198 @@ +--- +id: "index" +title: "@journeyapps/powersync-sdk-react-native" +sidebar_label: "Readme" +sidebar_position: 0 +custom_edit_url: null +--- + +# PowerSync SDK for React Native + +[PowerSync](https://powersync.co) is a service and set of SDKs that keeps Postgres databases in sync with on-device SQLite databases. See a summary of features [here](https://docs.powersync.co/client-sdk-references/react-native-and-expo). + +## Beta Release +This React Native SDK package is currently in a beta release. + +# Installation + +## Install Package + +```bash +npx expo install @journeyapps/powersync-sdk-react-native +``` + +## Install Peer Dependency: SQLite + +This SDK currently requires `@journeyapps/react-native-quick-sqlite` as a peer dependency. + +Install it in your app with: + +```bash +npx expo install @journeyapps/react-native-quick-sqlite +``` + +## Install Polyfills +### Fetch + +This SDK requires HTTP streaming in order to function. The following `fetch` polyfills are required for the React Native implementation of `fetch`: + + - react-native-fetch-api + - react-native-polyfill-globals + - react-native-url-polyfill + - text-encoding + - web-streams-polyfill + + These are listed as peer dependencies and need to be added to the React Native project + + ```bash + npx expo install react-native-fetch-api react-native-polyfill-globals react-native-url-polyfill text-encoding web-streams-polyfill base-64 react-native-get-random-values + ``` + + Enable the polyfills in React Native app with + + ```JavaScript +// App.js +import 'react-native-polyfill-globals/auto'; + ``` + +### Babel Plugins: Watched Queries + + Watched queries require support for Async Iterators. Expo apps currently require polyfill and Babel plugins in order to use this functionality. + + ```bash + npx expo install @azure/core-asynciterator-polyfill + ``` + + Make sure to import the polyfill early in your application + + ```JavaScript +// App.js + import '@azure/core-asynciterator-polyfill'; + ``` + +Install the async generator Babel plugin + + ```bash + yarn add -D @babel/plugin-transform-async-generator-functions + ``` + +Add the Babel plugin to your `babel.config.js` file + + ```JavaScript + module.exports = function (api) { + return { + presets: [...], + plugins: [ + // ... Other plugins + '@babel/plugin-transform-async-generator-functions' + ] + }; +}; + ``` + +## Native Projects + +This package uses native libraries. Create native Android and iOS projects (if not created already) with + +```bash +npx expo run:android +``` + +# Getting Started + +See our [Docs](https://docs.powersync.co/usage/installation/client-side-setup/integrating-with-your-backend#react-native-and-expo) for detailed instructions. + +```JavaScript +import { + Column, + ColumnType, + RNQSPowerSyncDatabaseOpenFactory, + Schema, + Table +} from '@journeyapps/powersync-sdk-react-native'; + +export const AppSchema = new Schema([ + new Table({ name: 'customers', columns: [new Column({ name: 'name', type: ColumnType.TEXT })] }) +]); + +let PowerSync; + +export const openDatabase = async () => { + const PowerSync = new RNQSPowerSyncDatabaseOpenFactory({ + schema: AppSchema, + dbFilename: 'test.sqlite' + //location: 'optional location directory to DB file' + }).getInstance(); + + await PowerSync.init(); + + // Run local statements. + await PowerSync.execute('INSERT INTO customers(id, name) VALUES(uuid(), ?)', ['Fred']); +}; + +class Connector { + async fetchCredentials() { + // TODO logic to fetch a session + return { + endpoint: '[The PowerSync instance URL]', + token: 'An authentication token', + expiresAt: 'When the token expires', + userID: 'User ID to associate the session with' + }; + } + + async uploadData(database) { + // Upload local changes to backend, see docs for example + } +} + +export const connectPowerSync = async () => { + const connector = new Connector(); // Which was declared above + await PowerSync.connect(connector); +}; + +// Use queries in React Components +export const CustomerListDisplay = () => { + const customers = usePowerSyncWatchedQuery('SELECT * from customers'); + + return ( + + {customers.map((l) => ( + {JSON.stringify(l)} + ))} + + ); +}; + +``` + +Refer to our [full documentation](https://docs.powersync.co/client-sdk-references/react-native-and-expo) to learn more. + +# Known Issues + +## Android +The PowerSync connection relies heavily on HTTP streams. React Native does not support streams out of the box, so we use the [polyfills](#polyfills-fetch) mentioned. There is currently an open [issue](https://github.com/facebook/flipper/issues/2495) where the Flipper network plugin does not allow Stream events to fire. This plugin needs to be [disabled](https://stackoverflow.com/questions/69235694/react-native-cant-connect-to-sse-in-android/69235695#69235695) in order for HTTP streams to work. + +Uncomment the following from +`android/app/src/debug/java/com//ReactNativeFlipper.java` +```java + // NetworkFlipperPlugin networkFlipperPlugin = new NetworkFlipperPlugin(); + // NetworkingModule.setCustomClientBuilder( + // new NetworkingModule.CustomClientBuilder() { + // @Override + // public void apply(OkHttpClient.Builder builder) { + // builder.addNetworkInterceptor(new FlipperOkhttpInterceptor(networkFlipperPlugin)); + // } + // }); + // client.addPlugin(networkFlipperPlugin); +``` + +Disable the dev client network inspector +`android/gradle.properties` +``` +# Enable network inspector +EX_DEV_CLIENT_NETWORK_INSPECTOR=false +``` + +## iOS +Testing offline mode on an iOS simulator by disabling the host machine's entire internet connection will cause the device to remain offline even after the internet connection has been restored. This issue seems to affect all network requests in an application. diff --git a/docs/docs/react-native-sdk/interfaces/AbstractStreamingSyncImplementationOptions.md b/docs/docs/react-native-sdk/interfaces/AbstractStreamingSyncImplementationOptions.md new file mode 100644 index 00000000..66f132cb --- /dev/null +++ b/docs/docs/react-native-sdk/interfaces/AbstractStreamingSyncImplementationOptions.md @@ -0,0 +1,65 @@ +--- +id: "AbstractStreamingSyncImplementationOptions" +title: "Interface: AbstractStreamingSyncImplementationOptions" +sidebar_label: "AbstractStreamingSyncImplementationOptions" +sidebar_position: 0 +custom_edit_url: null +--- + +## Properties + +### adapter + +• **adapter**: [`BucketStorageAdapter`](BucketStorageAdapter.md) + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/AbstractStreamingSyncImplementation.d.ts:21 + +___ + +### logger + +• `Optional` **logger**: `ILogger` + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/AbstractStreamingSyncImplementation.d.ts:24 + +___ + +### remote + +• **remote**: [`AbstractRemote`](../classes/AbstractRemote.md) + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/AbstractStreamingSyncImplementation.d.ts:22 + +___ + +### retryDelayMs + +• `Optional` **retryDelayMs**: `number` + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/AbstractStreamingSyncImplementation.d.ts:25 + +___ + +### uploadCrud + +• **uploadCrud**: () => `Promise`<`void`\> + +#### Type declaration + +▸ (): `Promise`<`void`\> + +##### Returns + +`Promise`<`void`\> + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/AbstractStreamingSyncImplementation.d.ts:23 diff --git a/docs/docs/react-native-sdk/interfaces/BaseObserverInterface.md b/docs/docs/react-native-sdk/interfaces/BaseObserverInterface.md new file mode 100644 index 00000000..6f9b9658 --- /dev/null +++ b/docs/docs/react-native-sdk/interfaces/BaseObserverInterface.md @@ -0,0 +1,49 @@ +--- +id: "BaseObserverInterface" +title: "Interface: BaseObserverInterface" +sidebar_label: "BaseObserverInterface" +sidebar_position: 0 +custom_edit_url: null +--- + +## Type parameters + +| Name | Type | +| :------ | :------ | +| `T` | extends [`BaseListener`](../modules.md#baselistener) | + +## Hierarchy + +- **`BaseObserverInterface`** + + ↳ [`DBAdapter`](DBAdapter.md) + +## Implemented by + +- [`BaseObserver`](../classes/BaseObserver.md) + +## Methods + +### registerListener + +▸ **registerListener**(`listener`): () => `void` + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `listener` | `Partial`<`T`\> | + +#### Returns + +`fn` + +▸ (): `void` + +##### Returns + +`void` + +#### Defined in + +powersync-sdk-common/lib/utils/BaseObserver.d.ts:2 diff --git a/docs/docs/react-native-sdk/interfaces/BucketChecksum.md b/docs/docs/react-native-sdk/interfaces/BucketChecksum.md new file mode 100644 index 00000000..e9cd0d84 --- /dev/null +++ b/docs/docs/react-native-sdk/interfaces/BucketChecksum.md @@ -0,0 +1,41 @@ +--- +id: "BucketChecksum" +title: "Interface: BucketChecksum" +sidebar_label: "BucketChecksum" +sidebar_position: 0 +custom_edit_url: null +--- + +## Properties + +### bucket + +• **bucket**: `string` + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/BucketStorageAdapter.d.ts:26 + +___ + +### checksum + +• **checksum**: `number` + +32-bit unsigned hash. + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/BucketStorageAdapter.d.ts:30 + +___ + +### count + +• **count**: `number` + +Count of operations - informational only. + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/BucketStorageAdapter.d.ts:34 diff --git a/docs/docs/react-native-sdk/interfaces/BucketRequest.md b/docs/docs/react-native-sdk/interfaces/BucketRequest.md new file mode 100644 index 00000000..46b420d1 --- /dev/null +++ b/docs/docs/react-native-sdk/interfaces/BucketRequest.md @@ -0,0 +1,29 @@ +--- +id: "BucketRequest" +title: "Interface: BucketRequest" +sidebar_label: "BucketRequest" +sidebar_position: 0 +custom_edit_url: null +--- + +## Properties + +### after + +• **after**: `string` + +Base-10 number. Sync all data from this bucket with op_id > after. + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/streaming-sync-types.d.ts:92 + +___ + +### name + +• **name**: `string` + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/streaming-sync-types.d.ts:88 diff --git a/docs/docs/react-native-sdk/interfaces/BucketState.md b/docs/docs/react-native-sdk/interfaces/BucketState.md new file mode 100644 index 00000000..875477a2 --- /dev/null +++ b/docs/docs/react-native-sdk/interfaces/BucketState.md @@ -0,0 +1,27 @@ +--- +id: "BucketState" +title: "Interface: BucketState" +sidebar_label: "BucketState" +sidebar_position: 0 +custom_edit_url: null +--- + +## Properties + +### bucket + +• **bucket**: `string` + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/BucketStorageAdapter.d.ts:10 + +___ + +### op\_id + +• **op\_id**: `string` + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/BucketStorageAdapter.d.ts:11 diff --git a/docs/docs/react-native-sdk/interfaces/BucketStorageAdapter.md b/docs/docs/react-native-sdk/interfaces/BucketStorageAdapter.md new file mode 100644 index 00000000..e2c98b00 --- /dev/null +++ b/docs/docs/react-native-sdk/interfaces/BucketStorageAdapter.md @@ -0,0 +1,247 @@ +--- +id: "BucketStorageAdapter" +title: "Interface: BucketStorageAdapter" +sidebar_label: "BucketStorageAdapter" +sidebar_position: 0 +custom_edit_url: null +--- + +## Implemented by + +- [`SqliteBucketStorage`](../classes/SqliteBucketStorage.md) + +## Methods + +### autoCompact + +▸ **autoCompact**(): `Promise`<`void`\> + +Exposed for tests only. + +#### Returns + +`Promise`<`void`\> + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/BucketStorageAdapter.d.ts:55 + +___ + +### forceCompact + +▸ **forceCompact**(): `Promise`<`void`\> + +Exposed for tests only. + +#### Returns + +`Promise`<`void`\> + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/BucketStorageAdapter.d.ts:59 + +___ + +### getBucketStates + +▸ **getBucketStates**(): `Promise`<[`BucketState`](BucketState.md)[]\> + +#### Returns + +`Promise`<[`BucketState`](BucketState.md)[]\> + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/BucketStorageAdapter.d.ts:42 + +___ + +### getCrudBatch + +▸ **getCrudBatch**(`limit?`): `Promise`<[`CrudBatch`](../classes/CrudBatch.md)\> + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `limit?` | `number` | + +#### Returns + +`Promise`<[`CrudBatch`](../classes/CrudBatch.md)\> + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/BucketStorageAdapter.d.ts:49 + +___ + +### getMaxOpId + +▸ **getMaxOpId**(): `string` + +#### Returns + +`string` + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/BucketStorageAdapter.d.ts:60 + +___ + +### hasCompletedSync + +▸ **hasCompletedSync**(): `Promise`<`boolean`\> + +#### Returns + +`Promise`<`boolean`\> + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/BucketStorageAdapter.d.ts:50 + +___ + +### hasCrud + +▸ **hasCrud**(): `Promise`<`boolean`\> + +#### Returns + +`Promise`<`boolean`\> + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/BucketStorageAdapter.d.ts:48 + +___ + +### init + +▸ **init**(): `Promise`<`void`\> + +#### Returns + +`Promise`<`void`\> + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/BucketStorageAdapter.d.ts:37 + +___ + +### removeBuckets + +▸ **removeBuckets**(`buckets`): `Promise`<`void`\> + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `buckets` | `string`[] | + +#### Returns + +`Promise`<`void`\> + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/BucketStorageAdapter.d.ts:39 + +___ + +### saveSyncData + +▸ **saveSyncData**(`batch`): `Promise`<`void`\> + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `batch` | [`SyncDataBatch`](../classes/SyncDataBatch.md) | + +#### Returns + +`Promise`<`void`\> + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/BucketStorageAdapter.d.ts:38 + +___ + +### setTargetCheckpoint + +▸ **setTargetCheckpoint**(`checkpoint`): `Promise`<`void`\> + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `checkpoint` | [`Checkpoint`](Checkpoint.md) | + +#### Returns + +`Promise`<`void`\> + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/BucketStorageAdapter.d.ts:40 + +___ + +### startSession + +▸ **startSession**(): `void` + +#### Returns + +`void` + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/BucketStorageAdapter.d.ts:41 + +___ + +### syncLocalDatabase + +▸ **syncLocalDatabase**(`checkpoint`): `Promise`<\{ `checkpointValid`: `boolean` ; `failures?`: `any`[] ; `ready`: `boolean` }\> + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `checkpoint` | [`Checkpoint`](Checkpoint.md) | + +#### Returns + +`Promise`<\{ `checkpointValid`: `boolean` ; `failures?`: `any`[] ; `ready`: `boolean` }\> + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/BucketStorageAdapter.d.ts:43 + +___ + +### updateLocalTarget + +▸ **updateLocalTarget**(`cb`): `Promise`<`boolean`\> + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `cb` | () => `Promise`<`string`\> | + +#### Returns + +`Promise`<`boolean`\> + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/BucketStorageAdapter.d.ts:51 diff --git a/docs/docs/react-native-sdk/interfaces/Checkpoint.md b/docs/docs/react-native-sdk/interfaces/Checkpoint.md new file mode 100644 index 00000000..59f08ed1 --- /dev/null +++ b/docs/docs/react-native-sdk/interfaces/Checkpoint.md @@ -0,0 +1,37 @@ +--- +id: "Checkpoint" +title: "Interface: Checkpoint" +sidebar_label: "Checkpoint" +sidebar_position: 0 +custom_edit_url: null +--- + +## Properties + +### buckets + +• **buckets**: [`BucketChecksum`](BucketChecksum.md)[] + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/BucketStorageAdapter.d.ts:6 + +___ + +### last\_op\_id + +• **last\_op\_id**: `string` + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/BucketStorageAdapter.d.ts:5 + +___ + +### write\_checkpoint + +• `Optional` **write\_checkpoint**: `string` + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/BucketStorageAdapter.d.ts:7 diff --git a/docs/docs/react-native-sdk/interfaces/ChecksumCache.md b/docs/docs/react-native-sdk/interfaces/ChecksumCache.md new file mode 100644 index 00000000..05aea00f --- /dev/null +++ b/docs/docs/react-native-sdk/interfaces/ChecksumCache.md @@ -0,0 +1,27 @@ +--- +id: "ChecksumCache" +title: "Interface: ChecksumCache" +sidebar_label: "ChecksumCache" +sidebar_position: 0 +custom_edit_url: null +--- + +## Properties + +### checksums + +• **checksums**: `Map`<`string`, \{ `checksum`: [`BucketChecksum`](BucketChecksum.md) ; `last_op_id`: `string` }\> + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/BucketStorageAdapter.d.ts:14 + +___ + +### lastOpId + +• **lastOpId**: `string` + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/BucketStorageAdapter.d.ts:18 diff --git a/docs/docs/react-native-sdk/interfaces/ColumnOptions.md b/docs/docs/react-native-sdk/interfaces/ColumnOptions.md new file mode 100644 index 00000000..c76e7ce3 --- /dev/null +++ b/docs/docs/react-native-sdk/interfaces/ColumnOptions.md @@ -0,0 +1,27 @@ +--- +id: "ColumnOptions" +title: "Interface: ColumnOptions" +sidebar_label: "ColumnOptions" +sidebar_position: 0 +custom_edit_url: null +--- + +## Properties + +### name + +• **name**: `string` + +#### Defined in + +powersync-sdk-common/lib/db/Column.d.ts:7 + +___ + +### type + +• `Optional` **type**: [`ColumnType`](../enums/ColumnType.md) + +#### Defined in + +powersync-sdk-common/lib/db/Column.d.ts:8 diff --git a/docs/docs/react-native-sdk/interfaces/ContinueCheckpointRequest.md b/docs/docs/react-native-sdk/interfaces/ContinueCheckpointRequest.md new file mode 100644 index 00000000..40531dc6 --- /dev/null +++ b/docs/docs/react-native-sdk/interfaces/ContinueCheckpointRequest.md @@ -0,0 +1,41 @@ +--- +id: "ContinueCheckpointRequest" +title: "Interface: ContinueCheckpointRequest" +sidebar_label: "ContinueCheckpointRequest" +sidebar_position: 0 +custom_edit_url: null +--- + +For sync2.json + +## Properties + +### buckets + +• **buckets**: [`BucketRequest`](BucketRequest.md)[] + +Existing bucket states. Only these buckets are synchronized. + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/streaming-sync-types.d.ts:11 + +___ + +### checkpoint\_token + +• **checkpoint\_token**: `string` + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/streaming-sync-types.d.ts:12 + +___ + +### limit + +• `Optional` **limit**: `number` + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/streaming-sync-types.d.ts:13 diff --git a/docs/docs/react-native-sdk/interfaces/CrudRequest.md b/docs/docs/react-native-sdk/interfaces/CrudRequest.md new file mode 100644 index 00000000..32d5b8a1 --- /dev/null +++ b/docs/docs/react-native-sdk/interfaces/CrudRequest.md @@ -0,0 +1,19 @@ +--- +id: "CrudRequest" +title: "Interface: CrudRequest" +sidebar_label: "CrudRequest" +sidebar_position: 0 +custom_edit_url: null +--- + +For crud.json + +## Properties + +### data + +• **data**: [`CrudEntry`](../classes/CrudEntry.md)[] + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/streaming-sync-types.d.ts:105 diff --git a/docs/docs/react-native-sdk/interfaces/CrudResponse.md b/docs/docs/react-native-sdk/interfaces/CrudResponse.md new file mode 100644 index 00000000..3e7af381 --- /dev/null +++ b/docs/docs/react-native-sdk/interfaces/CrudResponse.md @@ -0,0 +1,23 @@ +--- +id: "CrudResponse" +title: "Interface: CrudResponse" +sidebar_label: "CrudResponse" +sidebar_position: 0 +custom_edit_url: null +--- + +## Properties + +### checkpoint + +• `Optional` **checkpoint**: `string` + +A sync response with a checkpoint >= this checkpoint would contain all the changes in this request. + +Any earlier checkpoint may or may not contain these changes. + +May be empty when the request contains no ops. + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/streaming-sync-types.d.ts:115 diff --git a/docs/docs/react-native-sdk/interfaces/DBAdapter.md b/docs/docs/react-native-sdk/interfaces/DBAdapter.md new file mode 100644 index 00000000..43207c00 --- /dev/null +++ b/docs/docs/react-native-sdk/interfaces/DBAdapter.md @@ -0,0 +1,309 @@ +--- +id: "DBAdapter" +title: "Interface: DBAdapter" +sidebar_label: "DBAdapter" +sidebar_position: 0 +custom_edit_url: null +--- + +## Hierarchy + +- [`BaseObserverInterface`](BaseObserverInterface.md)<[`DBAdapterListener`](DBAdapterListener.md)\> + +- [`DBGetUtils`](DBGetUtils.md) + + ↳ **`DBAdapter`** + +## Implemented by + +- [`RNQSDBAdapter`](../classes/RNQSDBAdapter.md) + +## Properties + +### close + +• **close**: () => `void` + +#### Type declaration + +▸ (): `void` + +##### Returns + +`void` + +#### Defined in + +powersync-sdk-common/lib/db/DBAdapter.d.ts:63 + +___ + +### execute + +• **execute**: (`query`: `string`, `params?`: `any`[]) => `Promise`<[`QueryResult`](QueryResult.md)\> + +#### Type declaration + +▸ (`query`, `params?`): `Promise`<[`QueryResult`](QueryResult.md)\> + +##### Parameters + +| Name | Type | +| :------ | :------ | +| `query` | `string` | +| `params?` | `any`[] | + +##### Returns + +`Promise`<[`QueryResult`](QueryResult.md)\> + +#### Defined in + +powersync-sdk-common/lib/db/DBAdapter.d.ts:68 + +___ + +### readLock + +• **readLock**: (`fn`: (`tx`: [`LockContext`](LockContext.md)) => `Promise`<`T`\>, `options?`: [`DBLockOptions`](DBLockOptions.md)) => `Promise`<`T`\> + +#### Type declaration + +▸ <`T`\>(`fn`, `options?`): `Promise`<`T`\> + +##### Type parameters + +| Name | +| :------ | +| `T` | + +##### Parameters + +| Name | Type | +| :------ | :------ | +| `fn` | (`tx`: [`LockContext`](LockContext.md)) => `Promise`<`T`\> | +| `options?` | [`DBLockOptions`](DBLockOptions.md) | + +##### Returns + +`Promise`<`T`\> + +#### Defined in + +powersync-sdk-common/lib/db/DBAdapter.d.ts:64 + +___ + +### readTransaction + +• **readTransaction**: (`fn`: (`tx`: [`Transaction`](Transaction.md)) => `Promise`<`T`\>, `options?`: [`DBLockOptions`](DBLockOptions.md)) => `Promise`<`T`\> + +#### Type declaration + +▸ <`T`\>(`fn`, `options?`): `Promise`<`T`\> + +##### Type parameters + +| Name | +| :------ | +| `T` | + +##### Parameters + +| Name | Type | +| :------ | :------ | +| `fn` | (`tx`: [`Transaction`](Transaction.md)) => `Promise`<`T`\> | +| `options?` | [`DBLockOptions`](DBLockOptions.md) | + +##### Returns + +`Promise`<`T`\> + +#### Defined in + +powersync-sdk-common/lib/db/DBAdapter.d.ts:65 + +___ + +### writeLock + +• **writeLock**: (`fn`: (`tx`: [`LockContext`](LockContext.md)) => `Promise`<`T`\>, `options?`: [`DBLockOptions`](DBLockOptions.md)) => `Promise`<`T`\> + +#### Type declaration + +▸ <`T`\>(`fn`, `options?`): `Promise`<`T`\> + +##### Type parameters + +| Name | +| :------ | +| `T` | + +##### Parameters + +| Name | Type | +| :------ | :------ | +| `fn` | (`tx`: [`LockContext`](LockContext.md)) => `Promise`<`T`\> | +| `options?` | [`DBLockOptions`](DBLockOptions.md) | + +##### Returns + +`Promise`<`T`\> + +#### Defined in + +powersync-sdk-common/lib/db/DBAdapter.d.ts:66 + +___ + +### writeTransaction + +• **writeTransaction**: (`fn`: (`tx`: [`Transaction`](Transaction.md)) => `Promise`<`T`\>, `options?`: [`DBLockOptions`](DBLockOptions.md)) => `Promise`<`T`\> + +#### Type declaration + +▸ <`T`\>(`fn`, `options?`): `Promise`<`T`\> + +##### Type parameters + +| Name | +| :------ | +| `T` | + +##### Parameters + +| Name | Type | +| :------ | :------ | +| `fn` | (`tx`: [`Transaction`](Transaction.md)) => `Promise`<`T`\> | +| `options?` | [`DBLockOptions`](DBLockOptions.md) | + +##### Returns + +`Promise`<`T`\> + +#### Defined in + +powersync-sdk-common/lib/db/DBAdapter.d.ts:67 + +## Methods + +### get + +▸ **get**<`T`\>(`sql`, `parameters?`): `Promise`<`T`\> + +#### Type parameters + +| Name | +| :------ | +| `T` | + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `sql` | `string` | +| `parameters?` | `any`[] | + +#### Returns + +`Promise`<`T`\> + +#### Inherited from + +[DBGetUtils](DBGetUtils.md).[get](DBGetUtils.md#get) + +#### Defined in + +powersync-sdk-common/lib/db/DBAdapter.d.ts:34 + +___ + +### getAll + +▸ **getAll**<`T`\>(`sql`, `parameters?`): `Promise`<`T`[]\> + +#### Type parameters + +| Name | +| :------ | +| `T` | + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `sql` | `string` | +| `parameters?` | `any`[] | + +#### Returns + +`Promise`<`T`[]\> + +#### Inherited from + +[DBGetUtils](DBGetUtils.md).[getAll](DBGetUtils.md#getall) + +#### Defined in + +powersync-sdk-common/lib/db/DBAdapter.d.ts:32 + +___ + +### getOptional + +▸ **getOptional**<`T`\>(`sql`, `parameters?`): `Promise`<`T`\> + +#### Type parameters + +| Name | +| :------ | +| `T` | + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `sql` | `string` | +| `parameters?` | `any`[] | + +#### Returns + +`Promise`<`T`\> + +#### Inherited from + +[DBGetUtils](DBGetUtils.md).[getOptional](DBGetUtils.md#getoptional) + +#### Defined in + +powersync-sdk-common/lib/db/DBAdapter.d.ts:33 + +___ + +### registerListener + +▸ **registerListener**(`listener`): () => `void` + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `listener` | `Partial`<[`DBAdapterListener`](DBAdapterListener.md)\> | + +#### Returns + +`fn` + +▸ (): `void` + +##### Returns + +`void` + +#### Inherited from + +[BaseObserverInterface](BaseObserverInterface.md).[registerListener](BaseObserverInterface.md#registerlistener) + +#### Defined in + +powersync-sdk-common/lib/utils/BaseObserver.d.ts:2 diff --git a/docs/docs/react-native-sdk/interfaces/DBAdapterListener.md b/docs/docs/react-native-sdk/interfaces/DBAdapterListener.md new file mode 100644 index 00000000..3a1a2638 --- /dev/null +++ b/docs/docs/react-native-sdk/interfaces/DBAdapterListener.md @@ -0,0 +1,37 @@ +--- +id: "DBAdapterListener" +title: "Interface: DBAdapterListener" +sidebar_label: "DBAdapterListener" +sidebar_position: 0 +custom_edit_url: null +--- + +## Hierarchy + +- [`BaseListener`](../modules.md#baselistener) + + ↳ **`DBAdapterListener`** + +## Properties + +### tablesUpdated + +• **tablesUpdated**: (`updateNotification`: [`UpdateNotification`](UpdateNotification.md)) => `void` + +#### Type declaration + +▸ (`updateNotification`): `void` + +##### Parameters + +| Name | Type | +| :------ | :------ | +| `updateNotification` | [`UpdateNotification`](UpdateNotification.md) | + +##### Returns + +`void` + +#### Defined in + +powersync-sdk-common/lib/db/DBAdapter.d.ts:57 diff --git a/docs/docs/react-native-sdk/interfaces/DBGetUtils.md b/docs/docs/react-native-sdk/interfaces/DBGetUtils.md new file mode 100644 index 00000000..4efec55f --- /dev/null +++ b/docs/docs/react-native-sdk/interfaces/DBGetUtils.md @@ -0,0 +1,96 @@ +--- +id: "DBGetUtils" +title: "Interface: DBGetUtils" +sidebar_label: "DBGetUtils" +sidebar_position: 0 +custom_edit_url: null +--- + +## Hierarchy + +- **`DBGetUtils`** + + ↳ [`LockContext`](LockContext.md) + + ↳ [`DBAdapter`](DBAdapter.md) + +## Methods + +### get + +▸ **get**<`T`\>(`sql`, `parameters?`): `Promise`<`T`\> + +#### Type parameters + +| Name | +| :------ | +| `T` | + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `sql` | `string` | +| `parameters?` | `any`[] | + +#### Returns + +`Promise`<`T`\> + +#### Defined in + +powersync-sdk-common/lib/db/DBAdapter.d.ts:34 + +___ + +### getAll + +▸ **getAll**<`T`\>(`sql`, `parameters?`): `Promise`<`T`[]\> + +#### Type parameters + +| Name | +| :------ | +| `T` | + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `sql` | `string` | +| `parameters?` | `any`[] | + +#### Returns + +`Promise`<`T`[]\> + +#### Defined in + +powersync-sdk-common/lib/db/DBAdapter.d.ts:32 + +___ + +### getOptional + +▸ **getOptional**<`T`\>(`sql`, `parameters?`): `Promise`<`T`\> + +#### Type parameters + +| Name | +| :------ | +| `T` | + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `sql` | `string` | +| `parameters?` | `any`[] | + +#### Returns + +`Promise`<`T`\> + +#### Defined in + +powersync-sdk-common/lib/db/DBAdapter.d.ts:33 diff --git a/docs/docs/react-native-sdk/interfaces/DBLockOptions.md b/docs/docs/react-native-sdk/interfaces/DBLockOptions.md new file mode 100644 index 00000000..689f9b0b --- /dev/null +++ b/docs/docs/react-native-sdk/interfaces/DBLockOptions.md @@ -0,0 +1,17 @@ +--- +id: "DBLockOptions" +title: "Interface: DBLockOptions" +sidebar_label: "DBLockOptions" +sidebar_position: 0 +custom_edit_url: null +--- + +## Properties + +### timeoutMs + +• `Optional` **timeoutMs**: `number` + +#### Defined in + +powersync-sdk-common/lib/db/DBAdapter.d.ts:60 diff --git a/docs/docs/react-native-sdk/interfaces/IndexColumnOptions.md b/docs/docs/react-native-sdk/interfaces/IndexColumnOptions.md new file mode 100644 index 00000000..7df00cf5 --- /dev/null +++ b/docs/docs/react-native-sdk/interfaces/IndexColumnOptions.md @@ -0,0 +1,27 @@ +--- +id: "IndexColumnOptions" +title: "Interface: IndexColumnOptions" +sidebar_label: "IndexColumnOptions" +sidebar_position: 0 +custom_edit_url: null +--- + +## Properties + +### ascending + +• `Optional` **ascending**: `boolean` + +#### Defined in + +powersync-sdk-common/lib/db/schema/IndexedColumn.d.ts:5 + +___ + +### name + +• **name**: `string` + +#### Defined in + +powersync-sdk-common/lib/db/schema/IndexedColumn.d.ts:4 diff --git a/docs/docs/react-native-sdk/interfaces/IndexOptions.md b/docs/docs/react-native-sdk/interfaces/IndexOptions.md new file mode 100644 index 00000000..868df69a --- /dev/null +++ b/docs/docs/react-native-sdk/interfaces/IndexOptions.md @@ -0,0 +1,27 @@ +--- +id: "IndexOptions" +title: "Interface: IndexOptions" +sidebar_label: "IndexOptions" +sidebar_position: 0 +custom_edit_url: null +--- + +## Properties + +### columns + +• `Optional` **columns**: [`IndexedColumn`](../classes/IndexedColumn.md)[] + +#### Defined in + +powersync-sdk-common/lib/db/schema/Index.d.ts:5 + +___ + +### name + +• **name**: `string` + +#### Defined in + +powersync-sdk-common/lib/db/schema/Index.d.ts:4 diff --git a/docs/docs/react-native-sdk/interfaces/LockContext.md b/docs/docs/react-native-sdk/interfaces/LockContext.md new file mode 100644 index 00000000..7d327ea4 --- /dev/null +++ b/docs/docs/react-native-sdk/interfaces/LockContext.md @@ -0,0 +1,133 @@ +--- +id: "LockContext" +title: "Interface: LockContext" +sidebar_label: "LockContext" +sidebar_position: 0 +custom_edit_url: null +--- + +## Hierarchy + +- [`DBGetUtils`](DBGetUtils.md) + + ↳ **`LockContext`** + + ↳↳ [`Transaction`](Transaction.md) + +## Properties + +### execute + +• **execute**: (`query`: `string`, `params?`: `any`[]) => `Promise`<[`QueryResult`](QueryResult.md)\> + +#### Type declaration + +▸ (`query`, `params?`): `Promise`<[`QueryResult`](QueryResult.md)\> + +##### Parameters + +| Name | Type | +| :------ | :------ | +| `query` | `string` | +| `params?` | `any`[] | + +##### Returns + +`Promise`<[`QueryResult`](QueryResult.md)\> + +#### Defined in + +powersync-sdk-common/lib/db/DBAdapter.d.ts:37 + +## Methods + +### get + +▸ **get**<`T`\>(`sql`, `parameters?`): `Promise`<`T`\> + +#### Type parameters + +| Name | +| :------ | +| `T` | + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `sql` | `string` | +| `parameters?` | `any`[] | + +#### Returns + +`Promise`<`T`\> + +#### Inherited from + +[DBGetUtils](DBGetUtils.md).[get](DBGetUtils.md#get) + +#### Defined in + +powersync-sdk-common/lib/db/DBAdapter.d.ts:34 + +___ + +### getAll + +▸ **getAll**<`T`\>(`sql`, `parameters?`): `Promise`<`T`[]\> + +#### Type parameters + +| Name | +| :------ | +| `T` | + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `sql` | `string` | +| `parameters?` | `any`[] | + +#### Returns + +`Promise`<`T`[]\> + +#### Inherited from + +[DBGetUtils](DBGetUtils.md).[getAll](DBGetUtils.md#getall) + +#### Defined in + +powersync-sdk-common/lib/db/DBAdapter.d.ts:32 + +___ + +### getOptional + +▸ **getOptional**<`T`\>(`sql`, `parameters?`): `Promise`<`T`\> + +#### Type parameters + +| Name | +| :------ | +| `T` | + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `sql` | `string` | +| `parameters?` | `any`[] | + +#### Returns + +`Promise`<`T`\> + +#### Inherited from + +[DBGetUtils](DBGetUtils.md).[getOptional](DBGetUtils.md#getoptional) + +#### Defined in + +powersync-sdk-common/lib/db/DBAdapter.d.ts:33 diff --git a/docs/docs/react-native-sdk/interfaces/LockOptions.md b/docs/docs/react-native-sdk/interfaces/LockOptions.md new file mode 100644 index 00000000..70ebf7ff --- /dev/null +++ b/docs/docs/react-native-sdk/interfaces/LockOptions.md @@ -0,0 +1,53 @@ +--- +id: "LockOptions" +title: "Interface: LockOptions" +sidebar_label: "LockOptions" +sidebar_position: 0 +custom_edit_url: null +--- + +Abstract Lock to be implemented by various JS environments + +## Type parameters + +| Name | +| :------ | +| `T` | + +## Properties + +### callback + +• **callback**: () => `Promise`<`T`\> + +#### Type declaration + +▸ (): `Promise`<`T`\> + +##### Returns + +`Promise`<`T`\> + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/AbstractStreamingSyncImplementation.d.ts:16 + +___ + +### signal + +• `Optional` **signal**: `AbortSignal` + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/AbstractStreamingSyncImplementation.d.ts:18 + +___ + +### type + +• **type**: [`LockType`](../enums/LockType.md) + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/AbstractStreamingSyncImplementation.d.ts:17 diff --git a/docs/docs/react-native-sdk/interfaces/PowerSyncBackendConnector.md b/docs/docs/react-native-sdk/interfaces/PowerSyncBackendConnector.md new file mode 100644 index 00000000..cc46ebc4 --- /dev/null +++ b/docs/docs/react-native-sdk/interfaces/PowerSyncBackendConnector.md @@ -0,0 +1,65 @@ +--- +id: "PowerSyncBackendConnector" +title: "Interface: PowerSyncBackendConnector" +sidebar_label: "PowerSyncBackendConnector" +sidebar_position: 0 +custom_edit_url: null +--- + +## Properties + +### fetchCredentials + +• **fetchCredentials**: () => `Promise`<[`PowerSyncCredentials`](PowerSyncCredentials.md)\> + +#### Type declaration + +▸ (): `Promise`<[`PowerSyncCredentials`](PowerSyncCredentials.md)\> + +Get credentials for PowerSync. + +This should always fetch a fresh set of credentials - don't use cached +values. + +Return null if the user is not signed in. Throw an error if credentials +cannot be fetched due to a network error or other temporary error. + +This token is kept for the duration of a sync connection. + +##### Returns + +`Promise`<[`PowerSyncCredentials`](PowerSyncCredentials.md)\> + +#### Defined in + +powersync-sdk-common/lib/client/connection/PowerSyncBackendConnector.d.ts:14 + +___ + +### uploadData + +• **uploadData**: (`database`: [`AbstractPowerSyncDatabase`](../classes/AbstractPowerSyncDatabase.md)) => `Promise`<`void`\> + +#### Type declaration + +▸ (`database`): `Promise`<`void`\> + +Upload local changes to the app backend. + +Use [PowerSyncDatabase.getCrudBatch] to get a batch of changes to upload. See [DevConnector] for an example implementation. + +Any thrown errors will result in a retry after the configured wait period (default: 5 seconds). + +##### Parameters + +| Name | Type | +| :------ | :------ | +| `database` | [`AbstractPowerSyncDatabase`](../classes/AbstractPowerSyncDatabase.md) | + +##### Returns + +`Promise`<`void`\> + +#### Defined in + +powersync-sdk-common/lib/client/connection/PowerSyncBackendConnector.d.ts:21 diff --git a/docs/docs/react-native-sdk/interfaces/PowerSyncCredentials.md b/docs/docs/react-native-sdk/interfaces/PowerSyncCredentials.md new file mode 100644 index 00000000..162ad5ea --- /dev/null +++ b/docs/docs/react-native-sdk/interfaces/PowerSyncCredentials.md @@ -0,0 +1,37 @@ +--- +id: "PowerSyncCredentials" +title: "Interface: PowerSyncCredentials" +sidebar_label: "PowerSyncCredentials" +sidebar_position: 0 +custom_edit_url: null +--- + +## Properties + +### endpoint + +• **endpoint**: `string` + +#### Defined in + +powersync-sdk-common/lib/client/connection/PowerSyncCredentials.d.ts:2 + +___ + +### expiresAt + +• `Optional` **expiresAt**: `Date` + +#### Defined in + +powersync-sdk-common/lib/client/connection/PowerSyncCredentials.d.ts:4 + +___ + +### token + +• **token**: `string` + +#### Defined in + +powersync-sdk-common/lib/client/connection/PowerSyncCredentials.d.ts:3 diff --git a/docs/docs/react-native-sdk/interfaces/PowerSyncDBListener.md b/docs/docs/react-native-sdk/interfaces/PowerSyncDBListener.md new file mode 100644 index 00000000..1f16ea6c --- /dev/null +++ b/docs/docs/react-native-sdk/interfaces/PowerSyncDBListener.md @@ -0,0 +1,59 @@ +--- +id: "PowerSyncDBListener" +title: "Interface: PowerSyncDBListener" +sidebar_label: "PowerSyncDBListener" +sidebar_position: 0 +custom_edit_url: null +--- + +## Hierarchy + +- [`StreamingSyncImplementationListener`](StreamingSyncImplementationListener.md) + + ↳ **`PowerSyncDBListener`** + +## Properties + +### initialized + +• **initialized**: () => `void` + +#### Type declaration + +▸ (): `void` + +##### Returns + +`void` + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncDatabase.d.ts:29 + +___ + +### statusChanged + +• `Optional` **statusChanged**: (`status`: [`SyncStatus`](../classes/SyncStatus.md)) => `void` + +#### Type declaration + +▸ (`status`): `void` + +##### Parameters + +| Name | Type | +| :------ | :------ | +| `status` | [`SyncStatus`](../classes/SyncStatus.md) | + +##### Returns + +`void` + +#### Inherited from + +[StreamingSyncImplementationListener](StreamingSyncImplementationListener.md).[statusChanged](StreamingSyncImplementationListener.md#statuschanged) + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/AbstractStreamingSyncImplementation.d.ts:28 diff --git a/docs/docs/react-native-sdk/interfaces/PowerSyncDatabaseOptions.md b/docs/docs/react-native-sdk/interfaces/PowerSyncDatabaseOptions.md new file mode 100644 index 00000000..307ee709 --- /dev/null +++ b/docs/docs/react-native-sdk/interfaces/PowerSyncDatabaseOptions.md @@ -0,0 +1,47 @@ +--- +id: "PowerSyncDatabaseOptions" +title: "Interface: PowerSyncDatabaseOptions" +sidebar_label: "PowerSyncDatabaseOptions" +sidebar_position: 0 +custom_edit_url: null +--- + +## Properties + +### database + +• **database**: [`DBAdapter`](DBAdapter.md) + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncDatabase.d.ts:16 + +___ + +### logger + +• `Optional` **logger**: `ILogger` + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncDatabase.d.ts:18 + +___ + +### retryDelay + +• `Optional` **retryDelay**: `number` + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncDatabase.d.ts:17 + +___ + +### schema + +• **schema**: [`Schema`](../classes/Schema.md) + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncDatabase.d.ts:15 diff --git a/docs/docs/react-native-sdk/interfaces/PowerSyncOpenFactoryOptions.md b/docs/docs/react-native-sdk/interfaces/PowerSyncOpenFactoryOptions.md new file mode 100644 index 00000000..2fd07cdc --- /dev/null +++ b/docs/docs/react-native-sdk/interfaces/PowerSyncOpenFactoryOptions.md @@ -0,0 +1,41 @@ +--- +id: "PowerSyncOpenFactoryOptions" +title: "Interface: PowerSyncOpenFactoryOptions" +sidebar_label: "PowerSyncOpenFactoryOptions" +sidebar_position: 0 +custom_edit_url: null +--- + +## Properties + +### dbFilename + +• **dbFilename**: `string` + +Filename for the database. + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncOpenFactory.d.ts:9 + +___ + +### dbLocation + +• `Optional` **dbLocation**: `string` + +Directory where the database file is located. + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncOpenFactory.d.ts:13 + +___ + +### schema + +• **schema**: [`Schema`](../classes/Schema.md) + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncOpenFactory.d.ts:5 diff --git a/docs/docs/react-native-sdk/interfaces/QueryResult.md b/docs/docs/react-native-sdk/interfaces/QueryResult.md new file mode 100644 index 00000000..22df9726 --- /dev/null +++ b/docs/docs/react-native-sdk/interfaces/QueryResult.md @@ -0,0 +1,54 @@ +--- +id: "QueryResult" +title: "Interface: QueryResult" +sidebar_label: "QueryResult" +sidebar_position: 0 +custom_edit_url: null +--- + +Object returned by SQL Query executions { + insertId: Represent the auto-generated row id if applicable + rowsAffected: Number of affected rows if result of a update query + message: if status === 1, here you will find error description + rows: if status is undefined or 0 this object will contain the query results +} + + QueryResult + +## Properties + +### insertId + +• `Optional` **insertId**: `number` + +#### Defined in + +powersync-sdk-common/lib/db/DBAdapter.d.ts:17 + +___ + +### rows + +• `Optional` **rows**: `Object` + +#### Type declaration + +| Name | Type | Description | +| :------ | :------ | :------ | +| `_array` | `any`[] | Raw array with all dataset | +| `item` | (`idx`: `number`) => `any` | A convenience function to acess the index based the row object | +| `length` | `number` | The length of the dataset | + +#### Defined in + +powersync-sdk-common/lib/db/DBAdapter.d.ts:19 + +___ + +### rowsAffected + +• **rowsAffected**: `number` + +#### Defined in + +powersync-sdk-common/lib/db/DBAdapter.d.ts:18 diff --git a/docs/docs/react-native-sdk/interfaces/SQLWatchOptions.md b/docs/docs/react-native-sdk/interfaces/SQLWatchOptions.md new file mode 100644 index 00000000..ae6fec34 --- /dev/null +++ b/docs/docs/react-native-sdk/interfaces/SQLWatchOptions.md @@ -0,0 +1,37 @@ +--- +id: "SQLWatchOptions" +title: "Interface: SQLWatchOptions" +sidebar_label: "SQLWatchOptions" +sidebar_position: 0 +custom_edit_url: null +--- + +## Properties + +### signal + +• `Optional` **signal**: `AbortSignal` + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncDatabase.d.ts:21 + +___ + +### tables + +• `Optional` **tables**: `string`[] + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncDatabase.d.ts:22 + +___ + +### throttleMs + +• `Optional` **throttleMs**: `number` + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncDatabase.d.ts:23 diff --git a/docs/docs/react-native-sdk/interfaces/StreamingSyncCheckpoint.md b/docs/docs/react-native-sdk/interfaces/StreamingSyncCheckpoint.md new file mode 100644 index 00000000..189f07a8 --- /dev/null +++ b/docs/docs/react-native-sdk/interfaces/StreamingSyncCheckpoint.md @@ -0,0 +1,17 @@ +--- +id: "StreamingSyncCheckpoint" +title: "Interface: StreamingSyncCheckpoint" +sidebar_label: "StreamingSyncCheckpoint" +sidebar_position: 0 +custom_edit_url: null +--- + +## Properties + +### checkpoint + +• **checkpoint**: [`Checkpoint`](Checkpoint.md) + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/streaming-sync-types.d.ts:64 diff --git a/docs/docs/react-native-sdk/interfaces/StreamingSyncCheckpointComplete.md b/docs/docs/react-native-sdk/interfaces/StreamingSyncCheckpointComplete.md new file mode 100644 index 00000000..86f2fe8c --- /dev/null +++ b/docs/docs/react-native-sdk/interfaces/StreamingSyncCheckpointComplete.md @@ -0,0 +1,23 @@ +--- +id: "StreamingSyncCheckpointComplete" +title: "Interface: StreamingSyncCheckpointComplete" +sidebar_label: "StreamingSyncCheckpointComplete" +sidebar_position: 0 +custom_edit_url: null +--- + +## Properties + +### checkpoint\_complete + +• **checkpoint\_complete**: `Object` + +#### Type declaration + +| Name | Type | +| :------ | :------ | +| `last_op_id` | `string` | + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/streaming-sync-types.d.ts:78 diff --git a/docs/docs/react-native-sdk/interfaces/StreamingSyncCheckpointDiff.md b/docs/docs/react-native-sdk/interfaces/StreamingSyncCheckpointDiff.md new file mode 100644 index 00000000..2ec4a10b --- /dev/null +++ b/docs/docs/react-native-sdk/interfaces/StreamingSyncCheckpointDiff.md @@ -0,0 +1,26 @@ +--- +id: "StreamingSyncCheckpointDiff" +title: "Interface: StreamingSyncCheckpointDiff" +sidebar_label: "StreamingSyncCheckpointDiff" +sidebar_position: 0 +custom_edit_url: null +--- + +## Properties + +### checkpoint\_diff + +• **checkpoint\_diff**: `Object` + +#### Type declaration + +| Name | Type | +| :------ | :------ | +| `last_op_id` | `string` | +| `removed_buckets` | `string`[] | +| `updated_buckets` | [`BucketChecksum`](BucketChecksum.md)[] | +| `write_checkpoint` | `string` | + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/streaming-sync-types.d.ts:67 diff --git a/docs/docs/react-native-sdk/interfaces/StreamingSyncDataJSON.md b/docs/docs/react-native-sdk/interfaces/StreamingSyncDataJSON.md new file mode 100644 index 00000000..0c85ae81 --- /dev/null +++ b/docs/docs/react-native-sdk/interfaces/StreamingSyncDataJSON.md @@ -0,0 +1,17 @@ +--- +id: "StreamingSyncDataJSON" +title: "Interface: StreamingSyncDataJSON" +sidebar_label: "StreamingSyncDataJSON" +sidebar_position: 0 +custom_edit_url: null +--- + +## Properties + +### data + +• **data**: [`SyncDataBucketJSON`](../modules.md#syncdatabucketjson) + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/streaming-sync-types.d.ts:75 diff --git a/docs/docs/react-native-sdk/interfaces/StreamingSyncImplementationListener.md b/docs/docs/react-native-sdk/interfaces/StreamingSyncImplementationListener.md new file mode 100644 index 00000000..c273b20c --- /dev/null +++ b/docs/docs/react-native-sdk/interfaces/StreamingSyncImplementationListener.md @@ -0,0 +1,39 @@ +--- +id: "StreamingSyncImplementationListener" +title: "Interface: StreamingSyncImplementationListener" +sidebar_label: "StreamingSyncImplementationListener" +sidebar_position: 0 +custom_edit_url: null +--- + +## Hierarchy + +- [`BaseListener`](../modules.md#baselistener) + + ↳ **`StreamingSyncImplementationListener`** + + ↳↳ [`PowerSyncDBListener`](PowerSyncDBListener.md) + +## Properties + +### statusChanged + +• `Optional` **statusChanged**: (`status`: [`SyncStatus`](../classes/SyncStatus.md)) => `void` + +#### Type declaration + +▸ (`status`): `void` + +##### Parameters + +| Name | Type | +| :------ | :------ | +| `status` | [`SyncStatus`](../classes/SyncStatus.md) | + +##### Returns + +`void` + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/AbstractStreamingSyncImplementation.d.ts:28 diff --git a/docs/docs/react-native-sdk/interfaces/StreamingSyncKeepalive.md b/docs/docs/react-native-sdk/interfaces/StreamingSyncKeepalive.md new file mode 100644 index 00000000..3f0bd6ed --- /dev/null +++ b/docs/docs/react-native-sdk/interfaces/StreamingSyncKeepalive.md @@ -0,0 +1,19 @@ +--- +id: "StreamingSyncKeepalive" +title: "Interface: StreamingSyncKeepalive" +sidebar_label: "StreamingSyncKeepalive" +sidebar_position: 0 +custom_edit_url: null +--- + +## Properties + +### token\_expires\_in + +• **token\_expires\_in**: `number` + +If specified, token expires in this many seconds. + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/streaming-sync-types.d.ts:84 diff --git a/docs/docs/react-native-sdk/interfaces/StreamingSyncRequest.md b/docs/docs/react-native-sdk/interfaces/StreamingSyncRequest.md new file mode 100644 index 00000000..ffe8c3d8 --- /dev/null +++ b/docs/docs/react-native-sdk/interfaces/StreamingSyncRequest.md @@ -0,0 +1,55 @@ +--- +id: "StreamingSyncRequest" +title: "Interface: StreamingSyncRequest" +sidebar_label: "StreamingSyncRequest" +sidebar_position: 0 +custom_edit_url: null +--- + +## Properties + +### buckets + +• `Optional` **buckets**: [`BucketRequest`](BucketRequest.md)[] + +Existing bucket states. + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/streaming-sync-types.d.ts:49 + +___ + +### include\_checksum + +• **include\_checksum**: `boolean` + +Whether or not to compute a checksum for each checkpoint + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/streaming-sync-types.d.ts:57 + +___ + +### only + +• `Optional` **only**: `string`[] + +If specified, limit the response to only include these buckets. + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/streaming-sync-types.d.ts:53 + +___ + +### raw\_data + +• **raw\_data**: `boolean` + +Changes the response to stringified data in each OplogEntry + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/streaming-sync-types.d.ts:61 diff --git a/docs/docs/react-native-sdk/interfaces/SyncLocalDatabaseResult.md b/docs/docs/react-native-sdk/interfaces/SyncLocalDatabaseResult.md new file mode 100644 index 00000000..5dee6329 --- /dev/null +++ b/docs/docs/react-native-sdk/interfaces/SyncLocalDatabaseResult.md @@ -0,0 +1,37 @@ +--- +id: "SyncLocalDatabaseResult" +title: "Interface: SyncLocalDatabaseResult" +sidebar_label: "SyncLocalDatabaseResult" +sidebar_position: 0 +custom_edit_url: null +--- + +## Properties + +### checkpointValid + +• **checkpointValid**: `boolean` + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/BucketStorageAdapter.d.ts:22 + +___ + +### failures + +• `Optional` **failures**: `string`[] + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/BucketStorageAdapter.d.ts:23 + +___ + +### ready + +• **ready**: `boolean` + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/BucketStorageAdapter.d.ts:21 diff --git a/docs/docs/react-native-sdk/interfaces/SyncNewCheckpointRequest.md b/docs/docs/react-native-sdk/interfaces/SyncNewCheckpointRequest.md new file mode 100644 index 00000000..9fa2c4ee --- /dev/null +++ b/docs/docs/react-native-sdk/interfaces/SyncNewCheckpointRequest.md @@ -0,0 +1,46 @@ +--- +id: "SyncNewCheckpointRequest" +title: "Interface: SyncNewCheckpointRequest" +sidebar_label: "SyncNewCheckpointRequest" +sidebar_position: 0 +custom_edit_url: null +--- + +## Properties + +### buckets + +• `Optional` **buckets**: [`BucketRequest`](BucketRequest.md)[] + +Existing bucket states. Used if include_data is specified. + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/streaming-sync-types.d.ts:19 + +___ + +### limit + +• `Optional` **limit**: `number` + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/streaming-sync-types.d.ts:30 + +___ + +### request\_checkpoint + +• **request\_checkpoint**: `Object` + +#### Type declaration + +| Name | Type | Description | +| :------ | :------ | :------ | +| `include_checksum` | `boolean` | Whether or not to compute a checksum. | +| `include_data` | `boolean` | Whether or not to include an initial data request. | + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/streaming-sync-types.d.ts:20 diff --git a/docs/docs/react-native-sdk/interfaces/SyncResponse.md b/docs/docs/react-native-sdk/interfaces/SyncResponse.md new file mode 100644 index 00000000..2c518038 --- /dev/null +++ b/docs/docs/react-native-sdk/interfaces/SyncResponse.md @@ -0,0 +1,51 @@ +--- +id: "SyncResponse" +title: "Interface: SyncResponse" +sidebar_label: "SyncResponse" +sidebar_position: 0 +custom_edit_url: null +--- + +## Properties + +### checkpoint + +• `Optional` **checkpoint**: [`Checkpoint`](Checkpoint.md) + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/streaming-sync-types.d.ts:43 + +___ + +### checkpoint\_token + +• `Optional` **checkpoint\_token**: `string` + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/streaming-sync-types.d.ts:42 + +___ + +### data + +• `Optional` **data**: [`SyncDataBucketJSON`](../modules.md#syncdatabucketjson)[] + +Data for the buckets returned. May not have an an entry for each bucket in the request. + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/streaming-sync-types.d.ts:37 + +___ + +### has\_more + +• **has\_more**: `boolean` + +True if the response limit has been reached, and another request must be made. + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/streaming-sync-types.d.ts:41 diff --git a/docs/docs/react-native-sdk/interfaces/TableOptions.md b/docs/docs/react-native-sdk/interfaces/TableOptions.md new file mode 100644 index 00000000..f4935e1e --- /dev/null +++ b/docs/docs/react-native-sdk/interfaces/TableOptions.md @@ -0,0 +1,57 @@ +--- +id: "TableOptions" +title: "Interface: TableOptions" +sidebar_label: "TableOptions" +sidebar_position: 0 +custom_edit_url: null +--- + +## Properties + +### columns + +• **columns**: [`Column`](../classes/Column.md)[] + +#### Defined in + +powersync-sdk-common/lib/db/schema/Table.d.ts:5 + +___ + +### indexes + +• `Optional` **indexes**: [`Index`](../classes/Index.md)[] + +#### Defined in + +powersync-sdk-common/lib/db/schema/Table.d.ts:6 + +___ + +### insertOnly + +• `Optional` **insertOnly**: `boolean` + +#### Defined in + +powersync-sdk-common/lib/db/schema/Table.d.ts:8 + +___ + +### localOnly + +• `Optional` **localOnly**: `boolean` + +#### Defined in + +powersync-sdk-common/lib/db/schema/Table.d.ts:7 + +___ + +### name + +• **name**: `string` + +#### Defined in + +powersync-sdk-common/lib/db/schema/Table.d.ts:4 diff --git a/docs/docs/react-native-sdk/interfaces/Transaction.md b/docs/docs/react-native-sdk/interfaces/Transaction.md new file mode 100644 index 00000000..b7af5eef --- /dev/null +++ b/docs/docs/react-native-sdk/interfaces/Transaction.md @@ -0,0 +1,171 @@ +--- +id: "Transaction" +title: "Interface: Transaction" +sidebar_label: "Transaction" +sidebar_position: 0 +custom_edit_url: null +--- + +## Hierarchy + +- [`LockContext`](LockContext.md) + + ↳ **`Transaction`** + +## Properties + +### commit + +• **commit**: () => `Promise`<[`QueryResult`](QueryResult.md)\> + +#### Type declaration + +▸ (): `Promise`<[`QueryResult`](QueryResult.md)\> + +##### Returns + +`Promise`<[`QueryResult`](QueryResult.md)\> + +#### Defined in + +powersync-sdk-common/lib/db/DBAdapter.d.ts:40 + +___ + +### execute + +• **execute**: (`query`: `string`, `params?`: `any`[]) => `Promise`<[`QueryResult`](QueryResult.md)\> + +#### Type declaration + +▸ (`query`, `params?`): `Promise`<[`QueryResult`](QueryResult.md)\> + +##### Parameters + +| Name | Type | +| :------ | :------ | +| `query` | `string` | +| `params?` | `any`[] | + +##### Returns + +`Promise`<[`QueryResult`](QueryResult.md)\> + +#### Inherited from + +[LockContext](LockContext.md).[execute](LockContext.md#execute) + +#### Defined in + +powersync-sdk-common/lib/db/DBAdapter.d.ts:37 + +___ + +### rollback + +• **rollback**: () => `Promise`<[`QueryResult`](QueryResult.md)\> + +#### Type declaration + +▸ (): `Promise`<[`QueryResult`](QueryResult.md)\> + +##### Returns + +`Promise`<[`QueryResult`](QueryResult.md)\> + +#### Defined in + +powersync-sdk-common/lib/db/DBAdapter.d.ts:41 + +## Methods + +### get + +▸ **get**<`T`\>(`sql`, `parameters?`): `Promise`<`T`\> + +#### Type parameters + +| Name | +| :------ | +| `T` | + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `sql` | `string` | +| `parameters?` | `any`[] | + +#### Returns + +`Promise`<`T`\> + +#### Inherited from + +[LockContext](LockContext.md).[get](LockContext.md#get) + +#### Defined in + +powersync-sdk-common/lib/db/DBAdapter.d.ts:34 + +___ + +### getAll + +▸ **getAll**<`T`\>(`sql`, `parameters?`): `Promise`<`T`[]\> + +#### Type parameters + +| Name | +| :------ | +| `T` | + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `sql` | `string` | +| `parameters?` | `any`[] | + +#### Returns + +`Promise`<`T`[]\> + +#### Inherited from + +[LockContext](LockContext.md).[getAll](LockContext.md#getall) + +#### Defined in + +powersync-sdk-common/lib/db/DBAdapter.d.ts:32 + +___ + +### getOptional + +▸ **getOptional**<`T`\>(`sql`, `parameters?`): `Promise`<`T`\> + +#### Type parameters + +| Name | +| :------ | +| `T` | + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `sql` | `string` | +| `parameters?` | `any`[] | + +#### Returns + +`Promise`<`T`\> + +#### Inherited from + +[LockContext](LockContext.md).[getOptional](LockContext.md#getoptional) + +#### Defined in + +powersync-sdk-common/lib/db/DBAdapter.d.ts:33 diff --git a/docs/docs/react-native-sdk/interfaces/UpdateNotification.md b/docs/docs/react-native-sdk/interfaces/UpdateNotification.md new file mode 100644 index 00000000..e42b1d4d --- /dev/null +++ b/docs/docs/react-native-sdk/interfaces/UpdateNotification.md @@ -0,0 +1,37 @@ +--- +id: "UpdateNotification" +title: "Interface: UpdateNotification" +sidebar_label: "UpdateNotification" +sidebar_position: 0 +custom_edit_url: null +--- + +## Properties + +### opType + +• **opType**: [`RowUpdateType`](../enums/RowUpdateType.md) + +#### Defined in + +powersync-sdk-common/lib/db/DBAdapter.d.ts:52 + +___ + +### rowId + +• **rowId**: `number` + +#### Defined in + +powersync-sdk-common/lib/db/DBAdapter.d.ts:54 + +___ + +### table + +• **table**: `string` + +#### Defined in + +powersync-sdk-common/lib/db/DBAdapter.d.ts:53 diff --git a/docs/docs/react-native-sdk/interfaces/WatchOnChangeEvent.md b/docs/docs/react-native-sdk/interfaces/WatchOnChangeEvent.md new file mode 100644 index 00000000..f5934c5d --- /dev/null +++ b/docs/docs/react-native-sdk/interfaces/WatchOnChangeEvent.md @@ -0,0 +1,17 @@ +--- +id: "WatchOnChangeEvent" +title: "Interface: WatchOnChangeEvent" +sidebar_label: "WatchOnChangeEvent" +sidebar_position: 0 +custom_edit_url: null +--- + +## Properties + +### changedTables + +• **changedTables**: `string`[] + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncDatabase.d.ts:26 diff --git a/docs/docs/react-native-sdk/interfaces/_category_.yml b/docs/docs/react-native-sdk/interfaces/_category_.yml new file mode 100644 index 00000000..43bec88c --- /dev/null +++ b/docs/docs/react-native-sdk/interfaces/_category_.yml @@ -0,0 +1,2 @@ +label: "Interfaces" +position: 4 \ No newline at end of file diff --git a/docs/docs/react-native-sdk/modules.md b/docs/docs/react-native-sdk/modules.md new file mode 100644 index 00000000..8cdc0c72 --- /dev/null +++ b/docs/docs/react-native-sdk/modules.md @@ -0,0 +1,622 @@ +--- +id: "modules" +title: "@journeyapps/powersync-sdk-react-native" +sidebar_label: "Exports" +sidebar_position: 0.5 +custom_edit_url: null +--- + +## Enumerations + +- [ColumnType](enums/ColumnType.md) +- [LockType](enums/LockType.md) +- [OpTypeEnum](enums/OpTypeEnum.md) +- [RowUpdateType](enums/RowUpdateType.md) +- [UpdateType](enums/UpdateType.md) + +## Classes + +- [AbstractPowerSyncDatabase](classes/AbstractPowerSyncDatabase.md) +- [AbstractPowerSyncDatabaseOpenFactory](classes/AbstractPowerSyncDatabaseOpenFactory.md) +- [AbstractRemote](classes/AbstractRemote.md) +- [AbstractStreamingSyncImplementation](classes/AbstractStreamingSyncImplementation.md) +- [BaseObserver](classes/BaseObserver.md) +- [Column](classes/Column.md) +- [CrudBatch](classes/CrudBatch.md) +- [CrudEntry](classes/CrudEntry.md) +- [CrudTransaction](classes/CrudTransaction.md) +- [Index](classes/Index.md) +- [IndexedColumn](classes/IndexedColumn.md) +- [OpType](classes/OpType.md) +- [PowerSyncDatabase](classes/PowerSyncDatabase.md) +- [RNQSDBAdapter](classes/RNQSDBAdapter.md) +- [RNQSPowerSyncDatabaseOpenFactory](classes/RNQSPowerSyncDatabaseOpenFactory.md) +- [ReactNativeRemote](classes/ReactNativeRemote.md) +- [ReactNativeStreamingSyncImplementation](classes/ReactNativeStreamingSyncImplementation.md) +- [Schema](classes/Schema.md) +- [SqliteBucketStorage](classes/SqliteBucketStorage.md) +- [SyncDataBatch](classes/SyncDataBatch.md) +- [SyncDataBucket](classes/SyncDataBucket.md) +- [SyncStatus](classes/SyncStatus.md) +- [Table](classes/Table.md) +- [UploadQueueStats](classes/UploadQueueStats.md) + +## Interfaces + +- [AbstractStreamingSyncImplementationOptions](interfaces/AbstractStreamingSyncImplementationOptions.md) +- [BaseObserverInterface](interfaces/BaseObserverInterface.md) +- [BucketChecksum](interfaces/BucketChecksum.md) +- [BucketRequest](interfaces/BucketRequest.md) +- [BucketState](interfaces/BucketState.md) +- [BucketStorageAdapter](interfaces/BucketStorageAdapter.md) +- [Checkpoint](interfaces/Checkpoint.md) +- [ChecksumCache](interfaces/ChecksumCache.md) +- [ColumnOptions](interfaces/ColumnOptions.md) +- [ContinueCheckpointRequest](interfaces/ContinueCheckpointRequest.md) +- [CrudRequest](interfaces/CrudRequest.md) +- [CrudResponse](interfaces/CrudResponse.md) +- [DBAdapter](interfaces/DBAdapter.md) +- [DBAdapterListener](interfaces/DBAdapterListener.md) +- [DBGetUtils](interfaces/DBGetUtils.md) +- [DBLockOptions](interfaces/DBLockOptions.md) +- [IndexColumnOptions](interfaces/IndexColumnOptions.md) +- [IndexOptions](interfaces/IndexOptions.md) +- [LockContext](interfaces/LockContext.md) +- [LockOptions](interfaces/LockOptions.md) +- [PowerSyncBackendConnector](interfaces/PowerSyncBackendConnector.md) +- [PowerSyncCredentials](interfaces/PowerSyncCredentials.md) +- [PowerSyncDBListener](interfaces/PowerSyncDBListener.md) +- [PowerSyncDatabaseOptions](interfaces/PowerSyncDatabaseOptions.md) +- [PowerSyncOpenFactoryOptions](interfaces/PowerSyncOpenFactoryOptions.md) +- [QueryResult](interfaces/QueryResult.md) +- [SQLWatchOptions](interfaces/SQLWatchOptions.md) +- [StreamingSyncCheckpoint](interfaces/StreamingSyncCheckpoint.md) +- [StreamingSyncCheckpointComplete](interfaces/StreamingSyncCheckpointComplete.md) +- [StreamingSyncCheckpointDiff](interfaces/StreamingSyncCheckpointDiff.md) +- [StreamingSyncDataJSON](interfaces/StreamingSyncDataJSON.md) +- [StreamingSyncImplementationListener](interfaces/StreamingSyncImplementationListener.md) +- [StreamingSyncKeepalive](interfaces/StreamingSyncKeepalive.md) +- [StreamingSyncRequest](interfaces/StreamingSyncRequest.md) +- [SyncLocalDatabaseResult](interfaces/SyncLocalDatabaseResult.md) +- [SyncNewCheckpointRequest](interfaces/SyncNewCheckpointRequest.md) +- [SyncResponse](interfaces/SyncResponse.md) +- [TableOptions](interfaces/TableOptions.md) +- [Transaction](interfaces/Transaction.md) +- [UpdateNotification](interfaces/UpdateNotification.md) +- [WatchOnChangeEvent](interfaces/WatchOnChangeEvent.md) + +## Type Aliases + +### BaseListener + +Ƭ **BaseListener**: `Object` + +#### Index signature + +▪ [key: `string`]: (...`event`: `any`) => `any` + +#### Defined in + +powersync-sdk-common/lib/utils/BaseObserver.d.ts:4 + +___ + +### CrudEntryDataJSON + +Ƭ **CrudEntryDataJSON**: `Object` + +#### Type declaration + +| Name | Type | +| :------ | :------ | +| `data` | `Record`<`string`, `any`\> | +| `id` | `string` | +| `op` | [`UpdateType`](enums/UpdateType.md) | +| `type` | `string` | + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/CrudEntry.d.ts:17 + +___ + +### CrudEntryJSON + +Ƭ **CrudEntryJSON**: `Object` + +#### Type declaration + +| Name | Type | +| :------ | :------ | +| `data` | `string` | +| `id` | `string` | +| `tx_id?` | `number` | + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/CrudEntry.d.ts:12 + +___ + +### CrudEntryOutputJSON + +Ƭ **CrudEntryOutputJSON**: `Object` + +The output JSOn seems to be a third type of JSON, not the same as the input JSON. + +#### Type declaration + +| Name | Type | +| :------ | :------ | +| `data` | `Record`<`string`, `any`\> | +| `id` | `string` | +| `op` | [`UpdateType`](enums/UpdateType.md) | +| `op_id` | `number` | +| `tx_id?` | `number` | +| `type` | `string` | + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/CrudEntry.d.ts:26 + +___ + +### OpId + +Ƭ **OpId**: `string` + +64-bit unsigned integer stored as a string in base-10. + +Not sortable as a string. + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/CrudEntry.d.ts:6 + +___ + +### OpTypeJSON + +Ƭ **OpTypeJSON**: `string` + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/OpType.d.ts:7 + +___ + +### RemoteConnector + +Ƭ **RemoteConnector**: `Object` + +#### Type declaration + +| Name | Type | +| :------ | :------ | +| `fetchCredentials` | () => `Promise`<[`PowerSyncCredentials`](interfaces/PowerSyncCredentials.md)\> | + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/AbstractRemote.d.ts:4 + +___ + +### StreamingSyncLine + +Ƭ **StreamingSyncLine**: [`StreamingSyncDataJSON`](interfaces/StreamingSyncDataJSON.md) \| [`StreamingSyncCheckpoint`](interfaces/StreamingSyncCheckpoint.md) \| [`StreamingSyncCheckpointDiff`](interfaces/StreamingSyncCheckpointDiff.md) \| [`StreamingSyncCheckpointComplete`](interfaces/StreamingSyncCheckpointComplete.md) \| [`StreamingSyncKeepalive`](interfaces/StreamingSyncKeepalive.md) + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/streaming-sync-types.d.ts:86 + +___ + +### SyncDataBucketJSON + +Ƭ **SyncDataBucketJSON**: `Object` + +#### Type declaration + +| Name | Type | +| :------ | :------ | +| `after?` | `string` | +| `bucket` | `string` | +| `data` | `OplogEntryJSON`[] | +| `has_more?` | `boolean` | +| `next_after?` | `string` | + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/SyncDataBucket.d.ts:3 + +___ + +### SyncRequest + +Ƭ **SyncRequest**: [`ContinueCheckpointRequest`](interfaces/ContinueCheckpointRequest.md) \| [`SyncNewCheckpointRequest`](interfaces/SyncNewCheckpointRequest.md) + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/streaming-sync-types.d.ts:32 + +## Variables + +### DEFAULT\_INDEX\_COLUMN\_OPTIONS + +• `Const` **DEFAULT\_INDEX\_COLUMN\_OPTIONS**: `Partial`<[`IndexColumnOptions`](interfaces/IndexColumnOptions.md)\> + +#### Defined in + +powersync-sdk-common/lib/db/schema/IndexedColumn.d.ts:7 + +___ + +### DEFAULT\_INDEX\_OPTIONS + +• `Const` **DEFAULT\_INDEX\_OPTIONS**: `Partial`<[`IndexOptions`](interfaces/IndexOptions.md)\> + +#### Defined in + +powersync-sdk-common/lib/db/schema/Index.d.ts:7 + +___ + +### DEFAULT\_LOCK\_TIMEOUT\_MS + +• `Const` **DEFAULT\_LOCK\_TIMEOUT\_MS**: ``120000`` + +Requesting nested or recursive locks can block the application in some circumstances. +This default lock timeout will act as a failsafe to throw an error if a lock cannot +be obtained. + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncDatabase.d.ts:41 + +___ + +### DEFAULT\_POWERSYNC\_DB\_OPTIONS + +• `Const` **DEFAULT\_POWERSYNC\_DB\_OPTIONS**: `Object` + +#### Type declaration + +| Name | Type | +| :------ | :------ | +| `logger` | `ILogger` | +| `retryDelay` | `number` | + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncDatabase.d.ts:32 + +___ + +### DEFAULT\_REMOTE\_LOGGER + +• `Const` **DEFAULT\_REMOTE\_LOGGER**: `ILogger` + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/AbstractRemote.d.ts:7 + +___ + +### DEFAULT\_STREAMING\_SYNC\_OPTIONS + +• `Const` **DEFAULT\_STREAMING\_SYNC\_OPTIONS**: `Object` + +#### Type declaration + +| Name | Type | +| :------ | :------ | +| `logger` | `ILogger` | +| `retryDelayMs` | `number` | + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/AbstractStreamingSyncImplementation.d.ts:30 + +___ + +### DEFAULT\_TABLE\_OPTIONS + +• `Const` **DEFAULT\_TABLE\_OPTIONS**: `Partial`<[`TableOptions`](interfaces/TableOptions.md)\> + +#### Defined in + +powersync-sdk-common/lib/db/schema/Table.d.ts:10 + +___ + +### DEFAULT\_WATCH\_THROTTLE\_MS + +• `Const` **DEFAULT\_WATCH\_THROTTLE\_MS**: ``30`` + +#### Defined in + +powersync-sdk-common/lib/client/AbstractPowerSyncDatabase.d.ts:31 + +___ + +### MAX\_OP\_ID + +• `Const` **MAX\_OP\_ID**: ``"9223372036854775807"`` + +#### Defined in + +powersync-sdk-common/lib/client/sync/bucket/SyncDataBucket.d.ts:10 + +___ + +### PowerSyncContext + +• `Const` **PowerSyncContext**: `React.Context`<[`AbstractPowerSyncDatabase`](classes/AbstractPowerSyncDatabase.md)\> + +#### Defined in + +powersync-react/lib/hooks/PowerSyncContext.d.ts:3 + +___ + +### STREAMING\_POST\_TIMEOUT\_MS + +• `Const` **STREAMING\_POST\_TIMEOUT\_MS**: ``30000`` + +#### Defined in + +[powersync-sdk-react-native/src/sync/stream/ReactNativeRemote.ts:4](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-sdk-react-native/src/sync/stream/ReactNativeRemote.ts#L4) + +## Functions + +### isContinueCheckpointRequest + +▸ **isContinueCheckpointRequest**(`request`): request is ContinueCheckpointRequest + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `request` | [`SyncRequest`](modules.md#syncrequest) | + +#### Returns + +request is ContinueCheckpointRequest + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/streaming-sync-types.d.ts:99 + +___ + +### isStreamingKeepalive + +▸ **isStreamingKeepalive**(`line`): line is StreamingSyncKeepalive + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `line` | [`StreamingSyncLine`](modules.md#streamingsyncline) | + +#### Returns + +line is StreamingSyncKeepalive + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/streaming-sync-types.d.ts:95 + +___ + +### isStreamingSyncCheckpoint + +▸ **isStreamingSyncCheckpoint**(`line`): line is StreamingSyncCheckpoint + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `line` | [`StreamingSyncLine`](modules.md#streamingsyncline) | + +#### Returns + +line is StreamingSyncCheckpoint + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/streaming-sync-types.d.ts:96 + +___ + +### isStreamingSyncCheckpointComplete + +▸ **isStreamingSyncCheckpointComplete**(`line`): line is StreamingSyncCheckpointComplete + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `line` | [`StreamingSyncLine`](modules.md#streamingsyncline) | + +#### Returns + +line is StreamingSyncCheckpointComplete + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/streaming-sync-types.d.ts:97 + +___ + +### isStreamingSyncCheckpointDiff + +▸ **isStreamingSyncCheckpointDiff**(`line`): line is StreamingSyncCheckpointDiff + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `line` | [`StreamingSyncLine`](modules.md#streamingsyncline) | + +#### Returns + +line is StreamingSyncCheckpointDiff + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/streaming-sync-types.d.ts:98 + +___ + +### isStreamingSyncData + +▸ **isStreamingSyncData**(`line`): line is StreamingSyncDataJSON + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `line` | [`StreamingSyncLine`](modules.md#streamingsyncline) | + +#### Returns + +line is StreamingSyncDataJSON + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/streaming-sync-types.d.ts:94 + +___ + +### isSyncNewCheckpointRequest + +▸ **isSyncNewCheckpointRequest**(`request`): request is SyncNewCheckpointRequest + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `request` | [`SyncRequest`](modules.md#syncrequest) | + +#### Returns + +request is SyncNewCheckpointRequest + +#### Defined in + +powersync-sdk-common/lib/client/sync/stream/streaming-sync-types.d.ts:100 + +___ + +### quoteJsonPath + +▸ **quoteJsonPath**(`path`): `string` + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `path` | `string` | + +#### Returns + +`string` + +#### Defined in + +powersync-sdk-common/lib/utils/strings.d.ts:2 + +___ + +### quoteString + +▸ **quoteString**(`s`): `string` + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `s` | `string` | + +#### Returns + +`string` + +#### Defined in + +powersync-sdk-common/lib/utils/strings.d.ts:1 + +___ + +### usePowerSync + +▸ **usePowerSync**(): [`AbstractPowerSyncDatabase`](classes/AbstractPowerSyncDatabase.md) + +#### Returns + +[`AbstractPowerSyncDatabase`](classes/AbstractPowerSyncDatabase.md) + +#### Defined in + +powersync-react/lib/hooks/PowerSyncContext.d.ts:4 + +___ + +### usePowerSyncQuery + +▸ **usePowerSyncQuery**<`T`\>(`sqlStatement`, `parameters?`): `T`[] + +A hook to access a single static query. +For an updated result, use usePowerSyncWatchedQuery instead + +#### Type parameters + +| Name | Type | +| :------ | :------ | +| `T` | `any` | + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `sqlStatement` | `string` | +| `parameters?` | `any`[] | + +#### Returns + +`T`[] + +#### Defined in + +powersync-react/lib/hooks/usePowerSyncQuery.d.ts:5 + +___ + +### usePowerSyncWatchedQuery + +▸ **usePowerSyncWatchedQuery**<`T`\>(`sqlStatement`, `parameters?`, `options?`): `T`[] + +A hook to access the results of a watched query. + +#### Type parameters + +| Name | Type | +| :------ | :------ | +| `T` | `any` | + +#### Parameters + +| Name | Type | +| :------ | :------ | +| `sqlStatement` | `string` | +| `parameters?` | `any`[] | +| `options?` | `Omit`<[`SQLWatchOptions`](interfaces/SQLWatchOptions.md), ``"signal"``\> | + +#### Returns + +`T`[] + +#### Defined in + +powersync-react/lib/hooks/usePowerSyncWatchedQuery.d.ts:5 diff --git a/docs/docs/react-sdk/_category_.yml b/docs/docs/react-sdk/_category_.yml new file mode 100644 index 00000000..24a46026 --- /dev/null +++ b/docs/docs/react-sdk/_category_.yml @@ -0,0 +1 @@ +label: "API" \ No newline at end of file diff --git a/docs/docs/react-sdk/index.md b/docs/docs/react-sdk/index.md new file mode 100644 index 00000000..55958994 --- /dev/null +++ b/docs/docs/react-sdk/index.md @@ -0,0 +1,68 @@ +--- +id: "index" +title: "@journeyapps/powersync-react" +sidebar_label: "Readme" +sidebar_position: 0 +custom_edit_url: null +--- + +# React components for PowerSync + +This package is currently in a beta release. + +## Context +Configure a PowerSync DB connection and add it to a context provider. + +```JSX +// App.jsx +import { PowerSyncDatabase } from '@journeyapps/powersync-react-native'; +import { PowerSyncContext } from "@journeyapps/powersync-react"; +export const App = () => { + const powerSync = React.useMemo(() => { + // Setup PowerSync client + }, []) + + return + {/** Insert your components here */ } + +} +``` + +### Accessing PowerSync +The provided PowerSync client is available with the `usePowerSync` hook. + +```JSX +// TodoListDisplay.jsx +import { usePowerSync } from "@journeyapps/powersync-react"; + +export const TodoListDisplay = () => { + const powersync = usePowerSync(); + + const [lists, setLists] = React.useState([]); + + React.useEffect(() => { + powersync.getAll('SELECT * from lists').then(setLists) + }, []); + + return
    + {lists.map(list =>
  • {list.name}
  • )} +
+ } +``` + +### Watched Queries +Watched queries will automatically update when a dependant table is updated. +```JSX +// TodoListDisplay.jsx +import { usePowerSyncWatchedQuery } from "@journeyapps/powersync-react"; + +export const TodoListDisplay = () => { + const todoLists = usePowerSyncWatchedQuery('SELECT * from lists'); + + return + {todoLists.map((l) => ( + {JSON.stringify(l)} + ))} + +} +``` diff --git a/docs/docs/react-sdk/modules.md b/docs/docs/react-sdk/modules.md new file mode 100644 index 00000000..0ed51ae2 --- /dev/null +++ b/docs/docs/react-sdk/modules.md @@ -0,0 +1,91 @@ +--- +id: "modules" +title: "@journeyapps/powersync-react" +sidebar_label: "Exports" +sidebar_position: 0.5 +custom_edit_url: null +--- + +## Variables + +### PowerSyncContext + +• `Const` **PowerSyncContext**: `Context`<`AbstractPowerSyncDatabase`\> + +#### Defined in + +[hooks/PowerSyncContext.ts:4](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-react/src/hooks/PowerSyncContext.ts#L4) + +## Functions + +### usePowerSync + +▸ **usePowerSync**(): `AbstractPowerSyncDatabase` + +#### Returns + +`AbstractPowerSyncDatabase` + +#### Defined in + +[hooks/PowerSyncContext.ts:5](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-react/src/hooks/PowerSyncContext.ts#L5) + +___ + +### usePowerSyncQuery + +▸ **usePowerSyncQuery**<`T`\>(`sqlStatement`, `parameters?`): `T`[] + +A hook to access a single static query. +For an updated result, use usePowerSyncWatchedQuery instead + +#### Type parameters + +| Name | Type | +| :------ | :------ | +| `T` | `any` | + +#### Parameters + +| Name | Type | Default value | +| :------ | :------ | :------ | +| `sqlStatement` | `string` | `undefined` | +| `parameters` | `any`[] | `[]` | + +#### Returns + +`T`[] + +#### Defined in + +[hooks/usePowerSyncQuery.ts:8](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-react/src/hooks/usePowerSyncQuery.ts#L8) + +___ + +### usePowerSyncWatchedQuery + +▸ **usePowerSyncWatchedQuery**<`T`\>(`sqlStatement`, `parameters?`, `options?`): `T`[] + +A hook to access the results of a watched query. + +#### Type parameters + +| Name | Type | +| :------ | :------ | +| `T` | `any` | + +#### Parameters + +| Name | Type | Default value | +| :------ | :------ | :------ | +| `sqlStatement` | `string` | `undefined` | +| `parameters` | `any`[] | `[]` | +| `options` | `Omit`<`SQLWatchOptions`, ``"signal"``\> | `{}` | + +#### Returns + +`T`[] + +#### Defined in + +[hooks/usePowerSyncWatchedQuery.ts:8](https://github.com/powersync-ja/powersync-react-native-sdk/blob/65a3c12/packages/powersync-react/src/hooks/usePowerSyncWatchedQuery.ts#L8) diff --git a/docs/docusaurus.config.ts b/docs/docusaurus.config.ts new file mode 100644 index 00000000..f76c1a13 --- /dev/null +++ b/docs/docusaurus.config.ts @@ -0,0 +1,175 @@ +import { themes as prismThemes } from 'prism-react-renderer'; +import type { Config } from '@docusaurus/types'; +import type * as Preset from '@docusaurus/preset-classic'; + +const config: Config = { + title: 'React Native SDK Docs', + favicon: 'img/powersync-favicon.png', + markdown: { + format: 'detect' + }, + + // Set the production url of your site here + url: 'https://powersync.com', + // Set the // pathname under which your site is served + // For GitHub pages deployment, it is often '//' + baseUrl: '/', + + // GitHub pages deployment config. + // If you aren't using GitHub pages, you don't need these. + organizationName: 'powersync', // Usually your GitHub org/user name. + projectName: 'react-native-sdk-docs', // Usually your repo name. + + onBrokenLinks: 'warn', + onBrokenMarkdownLinks: 'warn', + + // Even if you don't use internationalization, you can use this field to set + // useful metadata like html lang. For example, if your site is Chinese, you + // may want to replace "en" with "zh-Hans". + i18n: { + defaultLocale: 'en', + locales: ['en'], + }, + + presets: [ + [ + 'classic', + { + docs: { + routeBasePath: '/', + sidebarPath: './sidebars.ts', + // Please change this to your repo. + // Remove this to remove the "edit this page" links. + editUrl: + 'https://github.com/powersync-ja/powersync-react-native-sdk', + }, + blog: false, + theme: { + customCss: './src/css/custom.css', + }, + } satisfies Preset.Options, + ], + ], + + plugins: [ + [ + 'docusaurus-plugin-typedoc', + + // Plugin / TypeDoc options + { + id: 'react-native-sdk', + entryPoints: ["../packages/powersync-sdk-react-native/src/index.ts"], + excludeExternals: true, + out: 'react-native-sdk', + tsconfig: "../packages/powersync-sdk-react-native/tsconfig.json", + }, + ], + [ + 'docusaurus-plugin-typedoc', + { + id: 'react-sdk', + excludeExternals: true, + entryPoints: ['../packages/powersync-react/src/index.ts'], + tsconfig: '../packages/powersync-react/tsconfig.json', + out: 'react-sdk', + }, + ], + [ + 'docusaurus-plugin-typedoc', + { + id: 'common-sdk', + excludeExternals: true, + entryPoints: ['../packages/powersync-sdk-common/src/index.ts'], + tsconfig: '../packages/powersync-sdk-common/tsconfig.json', + out: 'common-sdk', + }, + ], + [ + 'docusaurus-plugin-typedoc', + { + id: 'attachments-sdk', + excludeExternals: true, + entryPoints: ['../packages/powersync-attachments/src/index.ts'], + tsconfig: '../packages/powersync-attachments/tsconfig.json', + out: 'attachments-sdk', + }, + ], + ], + + themeConfig: { + // Replace with your project's social card + image: 'img/docusaurus-social-card.jpg', + navbar: { + title: 'PowerSync React Native SDK', + logo: { + alt: 'PowerSync Logo', + src: 'img/powersync-logo.png', + }, + items: [ + { + type: 'docSidebar', + sidebarId: 'docsSidebar', + position: 'left', + label: 'Docs', + }, + { + href: 'https://github.com/facebook/docusaurus', + label: 'GitHub', + position: 'right', + }, + ], + }, + footer: { + style: 'light', + links: [ + { + title: 'Community', + items: [ + { + label: 'Discord', + href: 'https://discordapp.com/invite/docusaurus', + }, + { + label: 'X', + href: 'https://twitter.com/powersync_', + }, + { + label: 'LinkedIn', + href: 'https://www.linkedin.com/showcase/journeyapps-powersync/', + }, + { + label: 'YouTube', + href: 'https://www.youtube.com/@powersync_', + }, + ], + }, + { + title: 'More', + items: [ + { + label: 'Website', + href: 'https://www.powersync.com/', + }, + { + label: 'GitHub', + href: 'https://github.com/powersync-ja/', + }, + ], + }, + ], + copyright: `Copyright © ${new Date().getFullYear()} Journey Mobile, Inc. + + + + + + `, + }, + prism: { + theme: prismThemes.github, + darkTheme: prismThemes.dracula, + }, + } satisfies Preset.ThemeConfig, +}; + +export default config; diff --git a/docs/package.json b/docs/package.json new file mode 100644 index 00000000..ae82bade --- /dev/null +++ b/docs/package.json @@ -0,0 +1,50 @@ +{ + "name": "docs", + "version": "0.0.0", + "private": true, + "scripts": { + "docusaurus": "docusaurus", + "start": "docusaurus start", + "build": "docusaurus build", + "swizzle": "docusaurus swizzle", + "deploy": "docusaurus deploy", + "clear": "docusaurus clear", + "serve": "docusaurus serve", + "write-translations": "docusaurus write-translations", + "write-heading-ids": "docusaurus write-heading-ids", + "typecheck": "tsc" + }, + "dependencies": { + "@docusaurus/core": "3.0.0", + "@docusaurus/preset-classic": "3.0.0", + "@mdx-js/react": "^3.0.0", + "clsx": "^1.2.1", + "prism-react-renderer": "^2.1.0", + "react": "^18.0.0", + "react-dom": "^18.0.0" + }, + "devDependencies": { + "@docusaurus/module-type-aliases": "3.0.0", + "@docusaurus/tsconfig": "3.0.0", + "@docusaurus/types": "3.0.0", + "docusaurus-plugin-typedoc": "^0.21.0", + "typedoc": "^0.25.4", + "typedoc-plugin-markdown": "^3.17.1", + "typescript": "~5.2.2" + }, + "browserslist": { + "production": [ + ">0.5%", + "not dead", + "not op_mini all" + ], + "development": [ + "last 3 chrome version", + "last 3 firefox version", + "last 5 safari version" + ] + }, + "engines": { + "node": ">=18.0" + } +} diff --git a/docs/sidebars.ts b/docs/sidebars.ts new file mode 100644 index 00000000..3979296e --- /dev/null +++ b/docs/sidebars.ts @@ -0,0 +1,63 @@ +import type { SidebarsConfig } from '@docusaurus/plugin-content-docs'; + +/** + * Creating a sidebar enables you to: + - create an ordered group of docs + - render a sidebar for each doc of that group + - provide next/previous navigation + + The sidebars can be generated from the filesystem, or explicitly defined here. + + Create as many sidebars as you want. + */ +const sidebars: SidebarsConfig = { + docsSidebar: [{ + type: 'category', + label: 'Libraries', + collapsible: false, + items: [ + { + type: 'category', + label: 'Common SDK', + items: [ + { + type: 'autogenerated', + dirName: 'common-sdk', + }, + ], + }, + { + type: 'category', + label: 'React Native SDK', + items: [ + { + type: 'autogenerated', + dirName: 'react-native-sdk', + }, + ], + }, + { + type: 'category', + label: 'Attachments SDK', + items: [ + { + type: 'autogenerated', + dirName: 'attachments-sdk', + }, + ], + }, + { + type: 'category', + label: 'React SDK', + items: [ + { + type: 'autogenerated', + dirName: 'react-sdk', + }, + ], + }, + ] + }] +}; + +export default sidebars; diff --git a/docs/src/css/custom.css b/docs/src/css/custom.css new file mode 100644 index 00000000..d1f5ec28 --- /dev/null +++ b/docs/src/css/custom.css @@ -0,0 +1,30 @@ +/** + * Any CSS included here will be global. The classic template + * bundles Infima by default. Infima is a CSS framework designed to + * work well for content-centric websites. + */ + +/* You can override the default Infima variables here. */ +:root { + --ifm-color-primary: #aa00ff; + --ifm-color-primary-dark: #9900e6; + --ifm-color-primary-darker: #9100d9; + --ifm-color-primary-darkest: #7700b3; + --ifm-color-primary-light: #b31aff; + --ifm-color-primary-lighter: #b726ff; + --ifm-color-primary-lightest: #c44dff; + --ifm-code-font-size: 95%; + --docusaurus-highlighted-code-line-bg: rgba(0, 0, 0, 0.1); +} + +/* For readability concerns, you should choose a lighter palette in dark mode. */ +[data-theme='dark'] { + --ifm-color-primary: #C44EFF; + --ifm-color-primary-dark: #b92dff; + --ifm-color-primary-darker: #b31cff; + --ifm-color-primary-darkest: #9b00e9; + --ifm-color-primary-light: #cf6fff; + --ifm-color-primary-lighter: #d580ff; + --ifm-color-primary-lightest: #e5b2ff; + --docusaurus-highlighted-code-line-bg: rgba(0, 0, 0, 0.3); +} diff --git a/docs/src/pages/index.module.css b/docs/src/pages/index.module.css new file mode 100644 index 00000000..9f71a5da --- /dev/null +++ b/docs/src/pages/index.module.css @@ -0,0 +1,23 @@ +/** + * CSS files with the .module.css suffix will be treated as CSS modules + * and scoped locally. + */ + +.heroBanner { + padding: 4rem 0; + text-align: center; + position: relative; + overflow: hidden; +} + +@media screen and (max-width: 996px) { + .heroBanner { + padding: 2rem; + } +} + +.buttons { + display: flex; + align-items: center; + justify-content: center; +} diff --git a/docs/src/pages/markdown-page.md b/docs/src/pages/markdown-page.md new file mode 100644 index 00000000..9756c5b6 --- /dev/null +++ b/docs/src/pages/markdown-page.md @@ -0,0 +1,7 @@ +--- +title: Markdown page example +--- + +# Markdown page example + +You don't need React to write simple standalone pages. diff --git a/docs/static/.nojekyll b/docs/static/.nojekyll new file mode 100644 index 00000000..e69de29b diff --git a/docs/static/img/powersync-favicon.png b/docs/static/img/powersync-favicon.png new file mode 100644 index 0000000000000000000000000000000000000000..96be8f92343e0d65781e02fa5bc819c50a5c9956 GIT binary patch literal 1208 zcmV;p1V{UcP)qRGl?JY`1koEbqp&WslqFEjC?x9R)^ z2_l%&W`gMEqGUZql%3vHOvJ^si|ll|yQ=(l$IMJNlOP`4%RDGjr0do9^WLlXhG=YK z8{2(0cGgF^U>L;JHgUx!p*Gmsj!pjufSfaQN+>lFYzY92IF4~8TozHh!Pd8JIt%>C z8G|U+CZE~xZ!o)K|7!sG)?-T~lsW}8fxp)wS|!GG@{}g_1_jFDrC)t#o$xhGoszsp zk}B{g_yd|roL?aU@V#~WQ~mr|FC>az$}&!RSlPhrLoCZ>uh^# z?8asReO)FVCoZ&hZ|cqNU3!Spw-3dK&7p_s zu6WQ0g}f-`nd^fR0Dw=(5hcL(KzT_%eX$w!bO?dg!mIALBm4QP<&rk*%iId0GyFhX z{Z0R%y{ms@97jkY?OEFs*-a787M}0TxB4WBy!4LFY=Bcr5T7s5d&zSOZMSqO0wq3 zpH}xpW-*+0Avi`bIyttiigh99F01LZ&|IgjKdw1rX-#O=Z=FU=d&%?uWcTSyiKJ)$l=FIHfu(LLT z2pk~#e*{3`|B54YmbMCg#I}WC+hMonyK8zp+KN_HlV)O%SiXS7TI$&$&!4_{sL>LaoQ4mM8YK*4T4bc0H2nHo}mfq(`Hy>OI`Q8^4phk9$h}dMAHB4)@VRBwn%M6$I zS!vkmJ076-aaNSqdm?}a?|o`{<4BRNqHCyOYd+#)BcSFThr@O;)yi>@@(&GrNOpYq zK-1E{5<-gYum)RHt5-ZLEa1YKbQvIKMT7p?v?Grs7_Zc9I?7zYBr!)nH6TT4qejj0h(ZN;!t zpjZIO<1|3{ketL3;R;&i0dU&RZ3abQ0B_w`82?`PY zC8fR8I9)TP#YZot>wW(8Mpiyc;7IJ?wnA$T;*cq{4TAT%p`?&iwiAf3xjGF@T7m#n z<6^qgS0SRvQqtgqMMZTIH6B=J%KP-|&E&uYjZ!~&6@vlPm}OgDWnoMy@>S7YrewRp zksZf3C_#9i^6IhmzJS!ozxT1lMrUwpr76lX%A4$cObzo^*Yg^$qT9z(U6I6ODO^mx z;N%ODo>PBrD4nWmsG7^2D_|x?2@EM?mS)Tf`OzT7acw(${$U$Em0nKM+<}dhV8>8=BCeh1Qq6ohCs2W@+ew zZ8#;9VKQ6;aP9^Rk1#e!Rmc6IU<+1U0yU1Hz2beVQDA_QBe#?jPnJ>MY?!cfRkp%~ zW5XpDQZ-72i`jzcb~l~ovkB03!B8VzFZO_%y-%~cUODmaeO4N#r$Bs8t*e$n3aa<`S1mkJ2&j( ztpwtTG$!lC3&i`>7ri{@QUR3heMTHPWCyEZKD|#?zQWJmop%*d#m5cWV?>H6b?PfV zA*49EVsi~}u}~}qlTkiWKEy_IB4(si7h&NC(;K9!nPno9h>`gdJPjX;ibmQD17m1g zqFI*i#u8w^9>>hJd^K4GmTG2AE965bn2W6f%LoA>JZ#6IyO6Wk7lT3hOxzGHlUmLu zm9Kxquh_dgmNi*E8REJR!ut%;!Vw7{YNQ>Qos;_YO_m6$Ip$Q?do)zu=c3u5UMSum zHA_wc62-}t3mY_vEfRKsG6oiy!D%iAHT2|2_!?#a&J7d4ZZS;mT=fQNa9}|S|4*m) z*#TNg-p6jx;C)OD(~6~)!tuRN$PFuh>xKdg^5%l8m{Q4YJ&~LjllSR*_Y0_<_Zbnf z@jiMX?aAOkY#2Xvh0xu(ehh28j~)|Kx=iTEomxqYX5JG7RN0P^1N$u4dY`Oen%Phh zAmgI2RQ;IsD7$`3$LMaBNV&aF360vkl&j*SifOWrdD#Nfmw|$E4Fp z4K4`-svE6}1N$s6!l?u`Oy8pbghPf??gr&?+K?Ca@s6HqDs@xFY>Hf0j%Nh{sG$q1 zET+iWm=tGGEhHys?<+Z8_#w>tRy3;>vN1B_vZ=sg0(!>1kEMJj4I|n#@tuhG>3~!9 zD^*my-H?d)QER|lY~N~RY{#(7+9f20ZRLHYB}~-&-2*NIplBbK>T4URtmj<%_##h^MoZW1NKi=Eyy?evc$bqwa>KN5eL!U`;RF)KA< zweO2I!(s=X#S=Lt8Ghx&B3D{PBGV*BtuHlTrfpIPMWy^kEK z6--uGl%Dqq%!#kf7{w!SHPTg)DstO76W+(yFhfNdHJ-xx$yH1&mpO^Nc!4k%orJxQ zrA8du$dlBpmVK6n9@y>(*lU=94;2uqPGwjvxhy%ZkSnrcSe{DVmCcqGVr@8T6a=6_ zW*J4!xA)m-*y;8@_m#t|E*A(}EvG6suqyU|8rd~tk+}C+X_(jJL^(+SI2KH$=6ymj z>LIk=6MYz*4+=Fa8X!{sEKFj;*4>1q^@n} zIpm8U$AC1L`T!0L3l@P;L8F0#FM$bIrwEp3Q8_-va4VgCBqoQ3E)vNy4a1;e%!;O! zOS}c64#`aTXUlz+wto9k?(y%3t>mv zoiajWzT7!##1S6Nv}!o;mu1C`VqN)2`N@@5-M{xyGQ(uf*iNiK7`EQ$gAYbUT{~yW z`)s6$7%Dk?di7#p!5LUW-p6Fl)Dit^vJo1C8gT&C$|2MH8q~%uqobeyJqv03&#?D# z#U>E-lDtp2@_l=sEpu{~;{l7KL#`Dyk`atis;O<(0Ansj|86K3jvnvS8uP!x>`!sz zsC|Pf+{yE0Ygi)crSH^pT&0@!)y*uLkn&{pd?CU$xS+sNRAh2ctqQIihM|3t6oQbB zoxuC^@X;dVozl|diwus~up~!bS9xt@A<-@^lMLV1sgg-u7Z?7O28&A@d9C}EF=H2l zd*SBMs9IS>%AL~o#^95Y|c(XPbdpFK+Ck{LB6ux>N3#TGCTdK=$ z+#ohVd7n_S&$BdGOf_P8A3vNb_P+bZqgO|Je6%S)ABz@a#{0<5wg{)V-sfHzZ583f zW8Qb+U=*)Ek+KeB&dXRaPdPRfa~^xLBF1QrdL;v#zRyHBZspS`jq>2ls$K>CyJ7q= zRI6gej77@M#>|=c_FH6UCgxn!rZZIlUWX*Cc?Muhh>Cq22UXA*7Eh?Tkfp^}*=ZlI2MhvHH z+|8p>JSamBhTn*buR^)<7GsX3)D`&X1*C0*AsAB2m_~jQGDo4)et(Ym45t_|6VpR` zcf>8DQNOmu{2n`w_vc{lr_m_H0VdiOi#7 zFO3`EhVkgs!Df{r`05MHcn3!hv*k*yTRL-zpjJJMz8ziq+YC>gj%VT1SFv;k3i5~^ zPhU8tYNY>@=0`eA?^6OwWtB_96_?_gp_Ur69k0EG?K=VWu4ebHxb_;NhiQ||v z6AL~<{wcHMD7{Zsg5ok2DqzqxKD|$$GIn6vW60QMCqLFA#PB|$J7>TX?45VET^a?i zcSqbj8VxMHZ{{3)T^MNeidcc%^>!hdGqn`JsnWyV9{Foq1rs4=Ky^Jr*) z8fLtXHEL&6b=|oiu9#rweK|+5;MM58UO~R6@fvk8Yy!Frv1kgwmM^eiG7jww-usLZ zSUlIc^2>|jy|0|sHt)u>v{VlYPz zV%8Ka|4b4sb$3Zgxae{Wy%CkFn%mDjfO-Ec+*MbfSCyI=b}zb(uoyOgO`l@!lgQrh z$Jdl9rANx$&ZYk+f@KsiW;oTVF>b#CZJS%nMSeaOe2(cKASXx1jpKJ$(}|#R6^yg^VCUvISq@a;^Z-w?zZWNVfUkUQ;T7rJch4c z#nLyCmuq8=mf;l94&V%$6p_z?6Eo?uBGDlI`CkPS+mebd?1YNhnfP`QvJT_?3s9aJUpr{k5xoW>`v}r@h?L6% ziyc3>8%t(KZ`qo*FWSV)JctjT!~B0n54y)poRM@qQh;4+uxb`6RztlD;7BiLlc{2L zv>%41J&?W$#}3eDSJIbo7UXzLViv73__qA zhH1^+U8Qmrj2e&r!|j}L$41P22|G7whveTY**Rm*LCpU>wk}Zj z!VIUVvBeK2wHh$V&ijmJRQP|b>KM{bd2TW9n?4)4CyE*t-o`2WVEHxK!kGfe;;Pj)`=^fwxmGE?|UQ~!au;T8)3yQ&lj0<_4kw{6kYE{Qz1z1~Cv35P(4)d05pbDu=9K5WPvtKszLJHbBV=#eY1q1M5G;zO`u35tWk7qyByo($_H*h#IXjx9~$0ECMNQIOQ<1YF5W!#fwK< zQ?YJ6Xxg@bvFLMaFuY za7sXmVk_22QtN(`$RNg1Mf6exLuS>gp#*E&wkTMtutU{y$iaYtxcld5-by!9p%7ZO zLBBybmW@5zxyGvT$3tmYG6z|Q(6lZ0d2mt~&AXu6aAfUA#&)`E875MVpc=f|--~J$ zVCT2kGB0Y2HJjA-#85#|{pbhSQ z00Rf30&g?3LPfOiibLtxyTdGvhWk(;QV_lGTQUcA8WVfys#LKGI$nZ$&9P?#anoKn##V|V-zHq1u;Ni^$24|4mb$XIJ`hu&Y%78Ae5h`1jlv!Jf!GB0H!9f9iZ zyxJIdEqW>DMU_@B#rv;e|2{aNnpJfw1pw~jC$jLyZ_%n7F25HI*l(_;wzY41+F_bN861`(i8kqtjLb|iHLUbq9jMq$XUs8WM9q;eH-@h#{+ z5)1y0HFLG?lLJs)5(*_F_Lejkc?5_kpj0C+cpv$Wg9j`*$Plw6i&Q=E(I**JxwUTH zG5RXb!WE^QEPV7fzL<+hJ~e({FqKT7E4LsYOJ-utLJYnIy~jo)Do(0i7gtR}ud6Wk zS?pb}Toqv$0GjqdmoZrUJaYC!qhw0#w96r1dyw9&ftG>m%ui#jgu37UbFzXgO3jg5xU))M?XL-vDM^vdK zR994osRbcTe-%?E7riVX50(B0sZ%LZR_;Q%8sEPiZ~YJcIRU%Zb4LpYT}R=*nHc&Y zDpeC3blm&Qu6d}Gj8T8WU31WN92|!pjCdA|X(S6f-qj~R2qBGI+GBM?#O;`#GZhn% z%Bzw)4$~0EUa9Nu!JYquYSq2Xs_*`UWe}&5Txn|ITpt0Iiy^V zduE`=Rd7NO_ZkG(bFrBgB$*ZE1yAf0}&~W-n1EpZa0YIq%}+*?+QVV*83oPpCDt!1wxt& z+Td2Q_eG>3Dv};hV|7ic*93R}9(Vp9>NYZYpGu#+KPDxi-_>~VE%X|L$~7?hA>8vi zTJ|79ocNE2_h8y1m@)zBTP;T3b_njAg(VbCxsUN*a!7j{|sOR^G3;c~e6O8ojYwCw@C_mR&} z>NLU6p2E#fqmJT1Tl;~S_!frTg9??ziHe^>{s}C40WXcircW(KUbhXd`!~i;Msg#Q zczdUjj^8=*ACbx{yw6d4pD+O8PxlgAJ1#aI?S7ANo@8QeCMBj=@l-V#cRY@bOECK- z?BB)cw{W9;$nEHJW%R~PpTgzQ|7Ykr0v|qsEuSl=<;X5fe+cJah@lUoF8lX_+6+U> zi?Qr=>|LoW<50gd11SJ9qbW7w2-{Th2Aip5n1z(Q`9`jgv;(A^5$)0%TUa<9m8&3S z823HTcDJlXjKZqNoWH=?<04t*tu#8L-DLWCCTxB1@v={K~ z&#`T-u9%QocE$ZKSW zgDKbJ!(Zd%F^iFFk{C`&%VDT42T9u9DNls1xRHz%4v~Q;9aKrTQ6wVnSM!WBA|vJS z!hb}tHx++>1XKQmL+RXQ2!+u5ay&d07mY(W>@hp>Uf{LJ=6tWUjC?ktROT@e=;J1 z!U8k*R}0Ip{v1!;js;Uuz+R+ERWWKJ?tC5%T8e{lPw2i)c=ay4`xuUL8{FnHSLIruVU;&sFF+zXOX(h$BWls@hdoW0!Q}Y z-AD1pT}a;oruT`vi{7k#tMH%knDZ#IGb~2#Ns^({tf;Gl?|rIG2Z6uB&tYP8{@p#bY=V(UDl+=U*uL<4rKBnRpANYvHk z;fX=I`hytwyJ|6>6|&=ZPuQqQviAuZTloK>biDW|UVoelq1?LS9p0M7c;+U|e+?&( z>jzPiDpkXX`!VrNwC>|k7vUT;(~y5c>3xV$-bbC6xJ6$0@6<7TIT`=H3_HK!4jWqU z^9U!eokYA(t`(9kjO%?y!W4<{KFLz!tGnh4Jb5SPOu@+$QVZ1GM$8#MeFM+_3@aB{ ztWlk2xN$OWn2b72B`cAxF2eh~8!p72oI2!+cbB;f({IAOUvVE}YxYGw5sxw6P1yTn zc?+B0xpP(4I2UaV>XVUo%T%4_Bs87;#@zia4o! zW%RigJ;vh8*YWMtlCLaFG@Ozz9&hzpEiv%dXm0gYyb({3L=Q>37LNW!WKH0uMk@9p z?2#ft`qaRY@IkTz{frnnmY3ncF1+?@RIEfHu3pZqU*pB4NVy7^u)ngbd?j3Z54w-V z!soDYp;BNBNb#_%P#t~lLzf#Yw)+93t-zKUiteNyl_{ban_8%7q)5e5k-^t6qKx{K zoQQ~vTlsYUSlnZ-^hJ`yc)SG)PT}i!u=-;Rx(hu##|1>f-dphEH zpRr^pgpT9U_W@L{#Trj6WvAhrC!$m#Vn)ii)f|-f3FX5?#G}$MMSQAK3snk-S>9*V zA*PDBiyb?R*-v8md${ZYoX`HsvSvMT+gn)mJ{CNM{F7?$CVQ8~qqt1H4jB3*>PUa1 zP?PdbVAU)5?giu>qtBfNMV&l17J(pD{8@Y-%kkbM!+XOi?(kA&;JN`O(|}R9;Q`dB zMRh7~QN~*aJwnGFYLL~XoBXsb`1b_NejF#VxGNe;LicgFYbM$bCT5`Ih&S$WT$`eR zcVNK5t=RIB#Y4l?Ie6<*EP1MsDr)Bf-Vcrdfg(8+RrHfVul_k?`Qj=`T{};La69e# zOhoRcGOs9uBT1NRoxhvn8fL(0z7E-8xSayw8!Y269p93$*xna!vG8e-m}= zMZ7lM(Y6QDb|CYBMa#P7)G{X*$UBa$pJU5ssNFmoPBBxBM(8pQRqJBknrI8+6j7Zj z*@_@92dVS%!{<1!4XR0Bo0gZ0l`mob1ngg{v^+=Q$nj2VwL^0?Scg_oO_7`Ol$e34 z8wIOtr%9e`-8~)h+A!2B_J5692C!l&xeii>vThLlvNEHC)8} zO9~DewnX32XwV$HH%H?hPrr)mp6t{S=2wrVSLY6-V&!z~U5f_oQJME`Sm6q2ei6Ej zM{X9<*OpwC23u4Q=HN!Goq`jGk&}UsZ^x!-$d$d%Z7gzY)MD4`iDrt6eAisHV!6D} ziO@)aLMoP$x_1=6c+DKvcw;)UO7>x-u8YP})%jmp)(k0yUjedfW8pQbwKjR3$SqT& zbqY&zWGB|lM7av6-=6zDkxAvyVj!9ihz8@?X*{H;lPVf^0n%4s$NZ>bX~HRSAtN*# z6>6aO@6i1bIEr(LD%MI@??SV@aEh!F1n?WxZfC)l!WG; z(Q_E~ZpD#(6cbtp6o;gSlBTxsLnIH|zrv<@NN$2!>aQ#lQnh;MbQO}DA$>JYW)p1D z{-_GQRpFEbsKx|aUxQ(9qv1tLs-j?h9JNAjI7K3*5UoP6B3=_w8;uokv766bTd?|b zn=kVODpW>~*q3>3Dso1Bw8shI8+Ssd5lG)u_~-l>EgV0B4Ig3O+Ng9foe>V|v_Q>cz_@9XtD z40s;N+Aq|Mry|9Y!zqRLL2s9?T2ZjLyHh6bb4Rc8JRUCmGS5t_FY`>o`CZWcG8{XC z^ljqu5Z)&(Oy|pR{flVWq3F)ILRGXK6eVo`R%B;**b?vQinAj5*tZ&Mr$_77@5mZ< zw4>^1Jpv87WB1oZ&dB#Z$CvkoLTGn0hD<@j{yOgy((aE-6w9rJKD@E09AkgPVd)%%%cF5??gP6DmC=3xF6fPnRAgpQZbFG=qmH=x&*(Ltc(Pl)KDu3j z3e~WCg;xvJr=NEm-!Ce3#tx{&7Tx4#=yV+%2N|oQp_?kA7g*u!P6-iM!~PijCfZz& zF#9ik=AFRW$=Lia*Iq_q-scG0T6d0%$lhoD-T^1q{bK}mnqu@sw7!r#5wVKjOv5KH z6@Hngy7y{zaOp&J83CBU%}m4M=dj^JVyLPus8AT)Za|-jQBC5f%w72Eaio3(&EsCr zswhHfSxYL^K>z2_e3Zpt0PL8F<-bABPO1yF_mw2I55_AxcU=_;02)rN%RS=-nzqBJ ziD=rvVp8(+uYC1r&|=x{aqJ&4NZS#*?> zfp4C~=669n_m$R9j>CkNu2csX{syhDwJ<&a`xayAqd2l22BZ`!rANwhZQOlj1Tr69 zAROr>R8ir)A(uu@2=W|s9fIL^qq@x>Q9gDAi(bZeGm5@(G+Z77ZbypMyO%)5W-NRH zyOsi!6KMjk*oO+$(0d}f-emV4Rr+dt`54l_W2=+|Us5@AxD(wTLV2q{h`c?jQafjh zEz98)`B{$<@#EcBL`qw(RLn* zkXGXB|3&(8Wv4Ok>vRu#Jc^Kw=N?#rB@g1jcdnL=-p59YP&MJld&WdcMXt1qWMr;< zMGUwJeXg@}Mol_)2w%L2)$bDCXC+rgF-vZV{=Y>tD_sG$PRG(eAZH&zK$D?JvG=~U z&tUzF3hy(9Q!2s~;gncDcI4jC5mrd#FPF_6v04$-Y=|L0M|;af5>kF1R=$ld|AySm zz`Tzr<0Y@@CAjE!sL9*@j-^w_u==l9^Ec!d|Eg{B1xWcLnpoZB7GT>uSn<0;@8gA2 zd>_<%pU{Fc@$!gj&&E1n@*Zb;pU3#Aip_gs=!2+l6Pw3V#um(a2!~Q>aLKdKd!Jlb zMQ13CE_b5WBX;+U2iD^2U*gDCbbkcxZ?*HjjHOuiD;!u(3X^JC^@1c77nX?8o~kjQo3_ z_ki<@;oOJNMkY$h`}F2jzGAf6sT?XM(*Pl_L@9WmGN>>7P`@wwJdX3&&S==3GT~Kv z-se!GbsiWNG3ZlidY?gBH0H=b;VkezVzFHxoDf>yh#tQ&JL8^(_-cap$;?^ieL`{` z7#bmO--6U38=bT2g6n-I+p-AcWgX(_nWjLw>ge_e+TB4v3(DG2=zX)Ot~uUk!YC;3 z6O!}bkcdiPbc~@$A!Wms&j_8_nnqNN1qwgc>V%YMQKL0h zKY>lJAd*LwH{qrCLI2*zL#n9yLxUn@IAy*mQ^}i=IYj}VBIFAf0uf#~MS#K!r-ToB zyvkL@sVor)Re7*Ot3;40smn`Y@uhu^Tq)McxY*VOcsGVt;go!DXzos3-oPk>B(j!= zDy=vr;(aWnEQKnbsBiQmVG4*jzLK3`?=t}!l=sP01?he6!s@z23qm{gN%}@Vb_jnq zdY@i_6brA9!TF%*Tvd;k%!d}Kv(x*86n5-&$awdsBqk8=vr-^xYYVUCA%z{abJ-E&4=Ht)MuE(xcG{4l z2B1OY>_jR+p5iI2XGOW{l5AMVTY-mD`Z(!yg;Qpv)aCgYot-M>P9=AR+;GY^05@8m zo*ObtEoNqa3u>{Jkkly9Cb=&!`6@0`!u3;Zh4=Oioh~NOWFcl@6%wH2ynu9Ol?}-!6oW_ zTBP(CopatNB;t>a6Q0NyAq@(8pGp8J>u`$UVm`f3FHXLY^67nN4yjlYAL#^)ly4=| z7B(ZLZte7hQ<|vg#}`hKDa_ZHAj2siyHjd9$wuVz=SDc?F03i9IC3^16-$b{LP59u ziI5KsJH6qQPO+G#_7mHk;wM+|UV7eVr9l3?Pwi-=uo=CN6DM)KPmR%!Bb*{rn7jFO z`n^vN90O3XQ=Uuu^ggnD0^WBHg;Qh-lS1WFgiN@Y6^O}-jrSR}r*y)ppP=^%NqoEE z40s=VkAPLo#`}EkPLX=U!zd`E&O+}KlI!gTHBuVw@rRU7!?Z~8qbPnjWiBia)hKKX zjD9rX6q#I)bVy%Q#VfYql-kPzVM}=zsU3j1uzC!-aO%gqJH=07AHL>Ku7cg2vIwV2 zd3TECgYJ&hbyY{sEu>1ht9SSodTkTR;2w>r&`7O5Y- zO1Tr`Av9%+N_R8)V_@NwYduH_Oi-oD!l?uk{Sev?7m5{TIHg;A%W%pZp{wy?MPL+C zW#N=6g@X*IR0P;Y=rVI>#QQiAdYShr619)zTGvFwDO*4jD0w=(Pk|K4&`-_#grt2| zXycD&?_-odt=`8Ap@IshaBe=C@ts)jyn~{|Hk{(?nGq?KP$jxM#kub*3#WKV{o0H_ z?^76=-qC1c%DnGfPIQbFz}}TVP<}*6{nWfqNC|B>aKkB^z$np&eTgGg7ET3`q<7wf z*qtiHaEc1Ox#1K$LN5!a5>Fm03?`h?f>P??R3H($x^5X#%%uGl`_tfk@{<`^Bg?$+ z98A)7!`bA0DkCdiNhEp29vqXxIQ83yIAs+c z>0_f(3#ZDED!oK(H;_K1_dc3{QhqX{39VQ{B{5VMP6e1;zf56_&`;-!F2RLUz9aOq za4M0ccpuB?eU?a>3#-RawmWq$rm)icd}z;^dNQM8Q5#Ot^pqhLPzndLl~DFpLRs>r maGCdsO_ik}(*F+t0RR7CHlh$wPizbT0000= 1.43.0 < 2" + +compression@^1.7.4: + version "1.7.4" + resolved "https://registry.yarnpkg.com/compression/-/compression-1.7.4.tgz#95523eff170ca57c29a0ca41e6fe131f41e5bb8f" + integrity sha512-jaSIDzP9pZVS4ZfQ+TzvtiWhdpFhE2RDHz8QJkpX9SIpLq88VueF5jJw6t+6CUQcAoA6t+x89MLrWAqpfDE8iQ== + dependencies: + accepts "~1.3.5" + bytes "3.0.0" + compressible "~2.0.16" + debug "2.6.9" + on-headers "~1.0.2" + safe-buffer "5.1.2" + vary "~1.1.2" + +concat-map@0.0.1: + version "0.0.1" + resolved "https://registry.yarnpkg.com/concat-map/-/concat-map-0.0.1.tgz#d8a96bd77fd68df7793a73036a3ba0d5405d477b" + integrity sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg== + +config-chain@^1.1.11: + version "1.1.13" + resolved "https://registry.yarnpkg.com/config-chain/-/config-chain-1.1.13.tgz#fad0795aa6a6cdaff9ed1b68e9dff94372c232f4" + integrity sha512-qj+f8APARXHrM0hraqXYb2/bOVSV4PvJQlNZ/DVj0QrmNM2q2euizkeuVckQ57J+W0mRH6Hvi+k50M4Jul2VRQ== + dependencies: + ini "^1.3.4" + proto-list "~1.2.1" + +configstore@^6.0.0: + version "6.0.0" + resolved "https://registry.yarnpkg.com/configstore/-/configstore-6.0.0.tgz#49eca2ebc80983f77e09394a1a56e0aca8235566" + integrity sha512-cD31W1v3GqUlQvbBCGcXmd2Nj9SvLDOP1oQ0YFuLETufzSPaKp11rYBsSOm7rCsW3OnIRAFM3OxRhceaXNYHkA== + dependencies: + dot-prop "^6.0.1" + graceful-fs "^4.2.6" + unique-string "^3.0.0" + write-file-atomic "^3.0.3" + xdg-basedir "^5.0.1" + +connect-history-api-fallback@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/connect-history-api-fallback/-/connect-history-api-fallback-2.0.0.tgz#647264845251a0daf25b97ce87834cace0f5f1c8" + integrity sha512-U73+6lQFmfiNPrYbXqr6kZ1i1wiRqXnp2nhMsINseWXO8lDau0LGEffJ8kQi4EjLZympVgRdvqjAgiZ1tgzDDA== + +consola@^2.15.3: + version "2.15.3" + resolved "https://registry.yarnpkg.com/consola/-/consola-2.15.3.tgz#2e11f98d6a4be71ff72e0bdf07bd23e12cb61550" + integrity sha512-9vAdYbHj6x2fLKC4+oPH0kFzY/orMZyG2Aj+kNylHxKGJ/Ed4dpNyAQYwJOdqO4zdM7XpVHmyejQDcQHrnuXbw== + +content-disposition@0.5.2: + version "0.5.2" + resolved "https://registry.yarnpkg.com/content-disposition/-/content-disposition-0.5.2.tgz#0cf68bb9ddf5f2be7961c3a85178cb85dba78cb4" + integrity sha512-kRGRZw3bLlFISDBgwTSA1TMBFN6J6GWDeubmDE3AF+3+yXL8hTWv8r5rkLbqYXY4RjPk/EzHnClI3zQf1cFmHA== + +content-disposition@0.5.4: + version "0.5.4" + resolved "https://registry.yarnpkg.com/content-disposition/-/content-disposition-0.5.4.tgz#8b82b4efac82512a02bb0b1dcec9d2c5e8eb5bfe" + integrity sha512-FveZTNuGw04cxlAiWbzi6zTAL/lhehaWbTtgluJh4/E95DqMwTmha3KZN1aAWA8cFIhHzMZUvLevkw5Rqk+tSQ== + dependencies: + safe-buffer "5.2.1" + +content-type@~1.0.4: + version "1.0.5" + resolved "https://registry.yarnpkg.com/content-type/-/content-type-1.0.5.tgz#8b773162656d1d1086784c8f23a54ce6d73d7918" + integrity sha512-nTjqfcBFEipKdXCv4YDQWCfmcLZKm81ldF0pAopTvyrFGVbcR6P/VAAd5G7N+0tTr8QqiU0tFadD6FK4NtJwOA== + +convert-source-map@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/convert-source-map/-/convert-source-map-2.0.0.tgz#4b560f649fc4e918dd0ab75cf4961e8bc882d82a" + integrity sha512-Kvp459HrV2FEJ1CAsi1Ku+MY3kasH19TFykTz2xWmMeq6bk2NU3XXvfJ+Q61m0xktWwt+1HSYf3JZsTms3aRJg== + +cookie-signature@1.0.6: + version "1.0.6" + resolved "https://registry.yarnpkg.com/cookie-signature/-/cookie-signature-1.0.6.tgz#e303a882b342cc3ee8ca513a79999734dab3ae2c" + integrity sha512-QADzlaHc8icV8I7vbaJXJwod9HWYp8uCqf1xa4OfNu1T7JVxQIrUgOWtHdNDtPiywmFbiS12VjotIXLrKM3orQ== + +cookie@0.5.0: + version "0.5.0" + resolved "https://registry.yarnpkg.com/cookie/-/cookie-0.5.0.tgz#d1f5d71adec6558c58f389987c366aa47e994f8b" + integrity sha512-YZ3GUyn/o8gfKJlnlX7g7xq4gyO6OSuhGPKaaGssGB2qgDUS0gPgtTvoyZLTt9Ab6dC4hfc9dV5arkvc/OCmrw== + +copy-text-to-clipboard@^3.2.0: + version "3.2.0" + resolved "https://registry.yarnpkg.com/copy-text-to-clipboard/-/copy-text-to-clipboard-3.2.0.tgz#0202b2d9bdae30a49a53f898626dcc3b49ad960b" + integrity sha512-RnJFp1XR/LOBDckxTib5Qjr/PMfkatD0MUCQgdpqS8MdKiNUzBjAQBEN6oUy+jW7LI93BBG3DtMB2KOOKpGs2Q== + +copy-webpack-plugin@^11.0.0: + version "11.0.0" + resolved "https://registry.yarnpkg.com/copy-webpack-plugin/-/copy-webpack-plugin-11.0.0.tgz#96d4dbdb5f73d02dd72d0528d1958721ab72e04a" + integrity sha512-fX2MWpamkW0hZxMEg0+mYnA40LTosOSa5TqZ9GYIBzyJa9C3QUaMPSE2xAi/buNr8u89SfD9wHSQVBzrRa/SOQ== + dependencies: + fast-glob "^3.2.11" + glob-parent "^6.0.1" + globby "^13.1.1" + normalize-path "^3.0.0" + schema-utils "^4.0.0" + serialize-javascript "^6.0.0" + +core-js-compat@^3.31.0, core-js-compat@^3.33.1: + version "3.33.3" + resolved "https://registry.yarnpkg.com/core-js-compat/-/core-js-compat-3.33.3.tgz#ec678b772c5a2d8a7c60a91c3a81869aa704ae01" + integrity sha512-cNzGqFsh3Ot+529GIXacjTJ7kegdt5fPXxCBVS1G0iaZpuo/tBz399ymceLJveQhFFZ8qThHiP3fzuoQjKN2ow== + dependencies: + browserslist "^4.22.1" + +core-js-pure@^3.30.2: + version "3.33.3" + resolved "https://registry.yarnpkg.com/core-js-pure/-/core-js-pure-3.33.3.tgz#cbf9180ac4c4653823d784862bfb5c77eac0bf98" + integrity sha512-taJ00IDOP+XYQEA2dAe4ESkmHt1fL8wzYDo3mRWQey8uO9UojlBFMneA65kMyxfYP7106c6LzWaq7/haDT6BCQ== + +core-js@^3.31.1: + version "3.33.3" + resolved "https://registry.yarnpkg.com/core-js/-/core-js-3.33.3.tgz#3c644a323f0f533a0d360e9191e37f7fc059088d" + integrity sha512-lo0kOocUlLKmm6kv/FswQL8zbkH7mVsLJ/FULClOhv8WRVmKLVcs6XPNQAzstfeJTCHMyButEwG+z1kHxHoDZw== + +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== + +cosmiconfig@^6.0.0: + version "6.0.0" + resolved "https://registry.yarnpkg.com/cosmiconfig/-/cosmiconfig-6.0.0.tgz#da4fee853c52f6b1e6935f41c1a2fc50bd4a9982" + integrity sha512-xb3ZL6+L8b9JLLCx3ZdoZy4+2ECphCMo2PwqgP1tlfVq6M6YReyzBJtvWWtbDSpNr9hn96pkCiZqUcFEc+54Qg== + dependencies: + "@types/parse-json" "^4.0.0" + import-fresh "^3.1.0" + parse-json "^5.0.0" + path-type "^4.0.0" + yaml "^1.7.2" + +cosmiconfig@^7.0.1: + version "7.1.0" + resolved "https://registry.yarnpkg.com/cosmiconfig/-/cosmiconfig-7.1.0.tgz#1443b9afa596b670082ea46cbd8f6a62b84635f6" + integrity sha512-AdmX6xUzdNASswsFtmwSt7Vj8po9IuqXm0UXz7QKPuEUmPB4XyjGfaAr2PSuELMwkRMVH1EpIkX5bTZGRB3eCA== + dependencies: + "@types/parse-json" "^4.0.0" + import-fresh "^3.2.1" + parse-json "^5.0.0" + path-type "^4.0.0" + yaml "^1.10.0" + +cosmiconfig@^8.2.0: + version "8.3.6" + resolved "https://registry.yarnpkg.com/cosmiconfig/-/cosmiconfig-8.3.6.tgz#060a2b871d66dba6c8538ea1118ba1ac16f5fae3" + integrity sha512-kcZ6+W5QzcJ3P1Mt+83OUv/oHFqZHIx8DuxG6eZ5RGMERoLqp4BuGjhHLYGK+Kf5XVkQvqBSmAy/nGWN3qDgEA== + dependencies: + import-fresh "^3.3.0" + js-yaml "^4.1.0" + parse-json "^5.2.0" + path-type "^4.0.0" + +cross-fetch@^3.1.5: + version "3.1.8" + resolved "https://registry.yarnpkg.com/cross-fetch/-/cross-fetch-3.1.8.tgz#0327eba65fd68a7d119f8fb2bf9334a1a7956f82" + integrity sha512-cvA+JwZoU0Xq+h6WkMvAUqPEYy92Obet6UdKLfW60qn99ftItKjB5T+BkyWOFWe2pUyfQ+IJHmpOTznqk1M6Kg== + dependencies: + node-fetch "^2.6.12" + +cross-spawn@^7.0.3: + version "7.0.3" + resolved "https://registry.yarnpkg.com/cross-spawn/-/cross-spawn-7.0.3.tgz#f73a85b9d5d41d045551c177e2882d4ac85728a6" + integrity sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w== + dependencies: + path-key "^3.1.0" + shebang-command "^2.0.0" + which "^2.0.1" + +crypto-random-string@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/crypto-random-string/-/crypto-random-string-4.0.0.tgz#5a3cc53d7dd86183df5da0312816ceeeb5bb1fc2" + integrity sha512-x8dy3RnvYdlUcPOjkEHqozhiwzKNSq7GcPuXFbnyMOCHxX8V3OgIg/pYuabl2sbUPfIJaeAQB7PMOK8DFIdoRA== + dependencies: + type-fest "^1.0.1" + +css-declaration-sorter@^6.3.1: + version "6.4.1" + resolved "https://registry.yarnpkg.com/css-declaration-sorter/-/css-declaration-sorter-6.4.1.tgz#28beac7c20bad7f1775be3a7129d7eae409a3a71" + integrity sha512-rtdthzxKuyq6IzqX6jEcIzQF/YqccluefyCYheovBOLhFT/drQA9zj/UbRAa9J7C0o6EG6u3E6g+vKkay7/k3g== + +css-loader@^6.8.1: + version "6.8.1" + resolved "https://registry.yarnpkg.com/css-loader/-/css-loader-6.8.1.tgz#0f8f52699f60f5e679eab4ec0fcd68b8e8a50a88" + integrity sha512-xDAXtEVGlD0gJ07iclwWVkLoZOpEvAWaSyf6W18S2pOC//K8+qUDIx8IIT3D+HjnmkJPQeesOPv5aiUaJsCM2g== + dependencies: + icss-utils "^5.1.0" + postcss "^8.4.21" + postcss-modules-extract-imports "^3.0.0" + postcss-modules-local-by-default "^4.0.3" + postcss-modules-scope "^3.0.0" + postcss-modules-values "^4.0.0" + postcss-value-parser "^4.2.0" + semver "^7.3.8" + +css-minimizer-webpack-plugin@^4.2.2: + version "4.2.2" + resolved "https://registry.yarnpkg.com/css-minimizer-webpack-plugin/-/css-minimizer-webpack-plugin-4.2.2.tgz#79f6199eb5adf1ff7ba57f105e3752d15211eb35" + integrity sha512-s3Of/4jKfw1Hj9CxEO1E5oXhQAxlayuHO2y/ML+C6I9sQ7FdzfEV6QgMLN3vI+qFsjJGIAFLKtQK7t8BOXAIyA== + dependencies: + cssnano "^5.1.8" + jest-worker "^29.1.2" + postcss "^8.4.17" + schema-utils "^4.0.0" + serialize-javascript "^6.0.0" + source-map "^0.6.1" + +css-select@^4.1.3: + version "4.3.0" + resolved "https://registry.yarnpkg.com/css-select/-/css-select-4.3.0.tgz#db7129b2846662fd8628cfc496abb2b59e41529b" + integrity sha512-wPpOYtnsVontu2mODhA19JrqWxNsfdatRKd64kmpRbQgh1KtItko5sTnEpPdpSaJszTOhEMlF/RPz28qj4HqhQ== + dependencies: + boolbase "^1.0.0" + css-what "^6.0.1" + domhandler "^4.3.1" + domutils "^2.8.0" + nth-check "^2.0.1" + +css-select@^5.1.0: + version "5.1.0" + resolved "https://registry.yarnpkg.com/css-select/-/css-select-5.1.0.tgz#b8ebd6554c3637ccc76688804ad3f6a6fdaea8a6" + integrity sha512-nwoRF1rvRRnnCqqY7updORDsuqKzqYJ28+oSMaJMMgOauh3fvwHqMS7EZpIPqK8GL+g9mKxF1vP/ZjSeNjEVHg== + dependencies: + boolbase "^1.0.0" + css-what "^6.1.0" + domhandler "^5.0.2" + domutils "^3.0.1" + nth-check "^2.0.1" + +css-tree@^1.1.2, css-tree@^1.1.3: + version "1.1.3" + resolved "https://registry.yarnpkg.com/css-tree/-/css-tree-1.1.3.tgz#eb4870fb6fd7707327ec95c2ff2ab09b5e8db91d" + integrity sha512-tRpdppF7TRazZrjJ6v3stzv93qxRcSsFmW6cX0Zm2NVKpxE1WV1HblnghVv9TreireHkqI/VDEsfolRF1p6y7Q== + dependencies: + mdn-data "2.0.14" + source-map "^0.6.1" + +css-what@^6.0.1, css-what@^6.1.0: + version "6.1.0" + resolved "https://registry.yarnpkg.com/css-what/-/css-what-6.1.0.tgz#fb5effcf76f1ddea2c81bdfaa4de44e79bac70f4" + integrity sha512-HTUrgRJ7r4dsZKU6GjmpfRK1O76h97Z8MfS1G0FozR+oF2kG6Vfe8JE6zwrkbxigziPHinCJ+gCPjA9EaBDtRw== + +cssesc@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/cssesc/-/cssesc-3.0.0.tgz#37741919903b868565e1c09ea747445cd18983ee" + integrity sha512-/Tb/JcjK111nNScGob5MNtsntNM1aCNUDipB/TkwZFhyDrrE47SOx/18wF2bbjgc3ZzCSKW1T5nt5EbFoAz/Vg== + +cssnano-preset-advanced@^5.3.10: + version "5.3.10" + resolved "https://registry.yarnpkg.com/cssnano-preset-advanced/-/cssnano-preset-advanced-5.3.10.tgz#25558a1fbf3a871fb6429ce71e41be7f5aca6eef" + integrity sha512-fnYJyCS9jgMU+cmHO1rPSPf9axbQyD7iUhLO5Df6O4G+fKIOMps+ZbU0PdGFejFBBZ3Pftf18fn1eG7MAPUSWQ== + dependencies: + autoprefixer "^10.4.12" + cssnano-preset-default "^5.2.14" + postcss-discard-unused "^5.1.0" + postcss-merge-idents "^5.1.1" + postcss-reduce-idents "^5.2.0" + postcss-zindex "^5.1.0" + +cssnano-preset-default@^5.2.14: + version "5.2.14" + resolved "https://registry.yarnpkg.com/cssnano-preset-default/-/cssnano-preset-default-5.2.14.tgz#309def4f7b7e16d71ab2438052093330d9ab45d8" + integrity sha512-t0SFesj/ZV2OTylqQVOrFgEh5uanxbO6ZAdeCrNsUQ6fVuXwYTxJPNAGvGTxHbD68ldIJNec7PyYZDBrfDQ+6A== + dependencies: + css-declaration-sorter "^6.3.1" + cssnano-utils "^3.1.0" + postcss-calc "^8.2.3" + postcss-colormin "^5.3.1" + postcss-convert-values "^5.1.3" + postcss-discard-comments "^5.1.2" + postcss-discard-duplicates "^5.1.0" + postcss-discard-empty "^5.1.1" + postcss-discard-overridden "^5.1.0" + postcss-merge-longhand "^5.1.7" + postcss-merge-rules "^5.1.4" + postcss-minify-font-values "^5.1.0" + postcss-minify-gradients "^5.1.1" + postcss-minify-params "^5.1.4" + postcss-minify-selectors "^5.2.1" + postcss-normalize-charset "^5.1.0" + postcss-normalize-display-values "^5.1.0" + postcss-normalize-positions "^5.1.1" + postcss-normalize-repeat-style "^5.1.1" + postcss-normalize-string "^5.1.0" + postcss-normalize-timing-functions "^5.1.0" + postcss-normalize-unicode "^5.1.1" + postcss-normalize-url "^5.1.0" + postcss-normalize-whitespace "^5.1.1" + postcss-ordered-values "^5.1.3" + postcss-reduce-initial "^5.1.2" + postcss-reduce-transforms "^5.1.0" + postcss-svgo "^5.1.0" + postcss-unique-selectors "^5.1.1" + +cssnano-utils@^3.1.0: + version "3.1.0" + resolved "https://registry.yarnpkg.com/cssnano-utils/-/cssnano-utils-3.1.0.tgz#95684d08c91511edfc70d2636338ca37ef3a6861" + integrity sha512-JQNR19/YZhz4psLX/rQ9M83e3z2Wf/HdJbryzte4a3NSuafyp9w/I4U+hx5C2S9g41qlstH7DEWnZaaj83OuEA== + +cssnano@^5.1.15, cssnano@^5.1.8: + version "5.1.15" + resolved "https://registry.yarnpkg.com/cssnano/-/cssnano-5.1.15.tgz#ded66b5480d5127fcb44dac12ea5a983755136bf" + integrity sha512-j+BKgDcLDQA+eDifLx0EO4XSA56b7uut3BQFH+wbSaSTuGLuiyTa/wbRYthUXX8LC9mLg+WWKe8h+qJuwTAbHw== + dependencies: + cssnano-preset-default "^5.2.14" + lilconfig "^2.0.3" + yaml "^1.10.2" + +csso@^4.2.0: + version "4.2.0" + resolved "https://registry.yarnpkg.com/csso/-/csso-4.2.0.tgz#ea3a561346e8dc9f546d6febedd50187cf389529" + integrity sha512-wvlcdIbf6pwKEk7vHj8/Bkc0B4ylXZruLvOgs9doS5eOsOpuodOV2zJChSpkp+pRpYQLQMeF04nr3Z68Sta9jA== + dependencies: + css-tree "^1.1.2" + +csstype@^3.0.2: + version "3.1.2" + resolved "https://registry.yarnpkg.com/csstype/-/csstype-3.1.2.tgz#1d4bf9d572f11c14031f0436e1c10bc1f571f50b" + integrity sha512-I7K1Uu0MBPzaFKg4nI5Q7Vs2t+3gWWW648spaF+Rg7pI9ds18Ugn+lvg4SHczUdKlHI5LWBXyqfS8+DufyBsgQ== + +debounce@^1.2.1: + version "1.2.1" + resolved "https://registry.yarnpkg.com/debounce/-/debounce-1.2.1.tgz#38881d8f4166a5c5848020c11827b834bcb3e0a5" + integrity sha512-XRRe6Glud4rd/ZGQfiV1ruXSfbvfJedlV9Y6zOlP+2K04vBYiJEte6stfFkCP03aMnY5tsipamumUjL14fofug== + +debug@2.6.9, debug@^2.6.0: + version "2.6.9" + resolved "https://registry.yarnpkg.com/debug/-/debug-2.6.9.tgz#5d128515df134ff327e90a4c93f4e077a536341f" + integrity sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA== + dependencies: + ms "2.0.0" + +debug@4, debug@^4.0.0, debug@^4.1.0, debug@^4.1.1: + version "4.3.4" + resolved "https://registry.yarnpkg.com/debug/-/debug-4.3.4.tgz#1319f6579357f2338d3337d2cdd4914bb5dcc865" + integrity sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ== + dependencies: + ms "2.1.2" + +decode-named-character-reference@^1.0.0: + version "1.0.2" + resolved "https://registry.yarnpkg.com/decode-named-character-reference/-/decode-named-character-reference-1.0.2.tgz#daabac9690874c394c81e4162a0304b35d824f0e" + integrity sha512-O8x12RzrUF8xyVcY0KJowWsmaJxQbmy0/EtnNtHRpsOcT7dFk5W598coHqBVpmWo1oQQfsCqfCmkZN5DJrZVdg== + dependencies: + character-entities "^2.0.0" + +decompress-response@^6.0.0: + version "6.0.0" + resolved "https://registry.yarnpkg.com/decompress-response/-/decompress-response-6.0.0.tgz#ca387612ddb7e104bd16d85aab00d5ecf09c66fc" + integrity sha512-aW35yZM6Bb/4oJlZncMH2LCoZtJXTRxES17vE3hoRiowU2kWHaJKFkSBDnDR+cm9J+9QhXmREyIfv0pji9ejCQ== + dependencies: + mimic-response "^3.1.0" + +deep-extend@^0.6.0: + version "0.6.0" + resolved "https://registry.yarnpkg.com/deep-extend/-/deep-extend-0.6.0.tgz#c4fa7c95404a17a9c3e8ca7e1537312b736330ac" + integrity sha512-LOHxIOaPYdHlJRtCQfDIVZtfw/ufM8+rVj649RIHzcm/vGwQRXFt6OPqIFWsm2XEMrNIEtWR64sY1LEKD2vAOA== + +deepmerge@^4.2.2: + version "4.3.1" + resolved "https://registry.yarnpkg.com/deepmerge/-/deepmerge-4.3.1.tgz#44b5f2147cd3b00d4b56137685966f26fd25dd4a" + integrity sha512-3sUqbMEc77XqpdNO7FRyRog+eW3ph+GYCbj+rK+uYyRMuwsVy0rMiVtPn+QJlKFvWP/1PYpapqYn0Me2knFn+A== + +default-gateway@^6.0.3: + version "6.0.3" + resolved "https://registry.yarnpkg.com/default-gateway/-/default-gateway-6.0.3.tgz#819494c888053bdb743edbf343d6cdf7f2943a71" + integrity sha512-fwSOJsbbNzZ/CUFpqFBqYfYNLj1NbMPm8MMCIzHjC83iSJRBEGmDUxU+WP661BaBQImeC2yHwXtz+P/O9o+XEg== + dependencies: + execa "^5.0.0" + +defer-to-connect@^2.0.1: + version "2.0.1" + resolved "https://registry.yarnpkg.com/defer-to-connect/-/defer-to-connect-2.0.1.tgz#8016bdb4143e4632b77a3449c6236277de520587" + integrity sha512-4tvttepXG1VaYGrRibk5EwJd1t4udunSOVMdLSAL6mId1ix438oPwPZMALY41FCijukO1L0twNcGsdzS7dHgDg== + +define-data-property@^1.0.1, define-data-property@^1.1.1: + version "1.1.1" + resolved "https://registry.yarnpkg.com/define-data-property/-/define-data-property-1.1.1.tgz#c35f7cd0ab09883480d12ac5cb213715587800b3" + integrity sha512-E7uGkTzkk1d0ByLeSc6ZsFS79Axg+m1P/VsgYsxHgiuc3tFSj+MjMIwe90FC4lOAZzNBdY7kkO2P2wKdsQ1vgQ== + dependencies: + get-intrinsic "^1.2.1" + gopd "^1.0.1" + has-property-descriptors "^1.0.0" + +define-lazy-prop@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/define-lazy-prop/-/define-lazy-prop-2.0.0.tgz#3f7ae421129bcaaac9bc74905c98a0009ec9ee7f" + integrity sha512-Ds09qNh8yw3khSjiJjiUInaGX9xlqZDY7JVryGxdxV7NPeuqQfplOpQ66yJFZut3jLa5zOwkXw1g9EI2uKh4Og== + +define-properties@^1.1.4: + version "1.2.1" + resolved "https://registry.yarnpkg.com/define-properties/-/define-properties-1.2.1.tgz#10781cc616eb951a80a034bafcaa7377f6af2b6c" + integrity sha512-8QmQKqEASLd5nx0U1B1okLElbUuuttJ/AnYmRXbbbGDWh6uS208EjD4Xqq/I9wK7u0v6O08XhTWnt5XtEbR6Dg== + dependencies: + define-data-property "^1.0.1" + has-property-descriptors "^1.0.0" + object-keys "^1.1.1" + +del@^6.1.1: + version "6.1.1" + resolved "https://registry.yarnpkg.com/del/-/del-6.1.1.tgz#3b70314f1ec0aa325c6b14eb36b95786671edb7a" + integrity sha512-ua8BhapfP0JUJKC/zV9yHHDW/rDoDxP4Zhn3AkA6/xT6gY7jYXJiaeyBZznYVujhZZET+UgcbZiQ7sN3WqcImg== + dependencies: + globby "^11.0.1" + graceful-fs "^4.2.4" + is-glob "^4.0.1" + is-path-cwd "^2.2.0" + is-path-inside "^3.0.2" + p-map "^4.0.0" + rimraf "^3.0.2" + slash "^3.0.0" + +delayed-stream@~1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/delayed-stream/-/delayed-stream-1.0.0.tgz#df3ae199acadfb7d440aaae0b29e2272b24ec619" + integrity sha512-ZySD7Nf91aLB0RxL4KGrKHBXl7Eds1DAmEdcoVawXnLD7SDhpNgtuII2aAkg7a7QS41jxPSZ17p4VdGnMHk3MQ== + +depd@2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/depd/-/depd-2.0.0.tgz#b696163cc757560d09cf22cc8fad1571b79e76df" + integrity sha512-g7nH6P6dyDioJogAAGprGpCtVImJhpPk/roCzdb3fIh61/s/nPsfR6onyMwkCAR/OlC3yBC0lESvUoQEAssIrw== + +depd@~1.1.2: + version "1.1.2" + resolved "https://registry.yarnpkg.com/depd/-/depd-1.1.2.tgz#9bcd52e14c097763e749b274c4346ed2e560b5a9" + integrity sha512-7emPTl6Dpo6JRXOXjLRxck+FlLRX5847cLKEn00PLAgc3g2hTZZgr+e4c2v6QpSmLeFP3n5yUo7ft6avBK/5jQ== + +dequal@^2.0.0: + version "2.0.3" + resolved "https://registry.yarnpkg.com/dequal/-/dequal-2.0.3.tgz#2644214f1997d39ed0ee0ece72335490a7ac67be" + integrity sha512-0je+qPKHEMohvfRTCEo3CrPG6cAzAYgmzKyxRiYSSDkS6eGJdyVJm7WaYA5ECaAD9wLB2T4EEeymA5aFVcYXCA== + +destroy@1.2.0: + version "1.2.0" + resolved "https://registry.yarnpkg.com/destroy/-/destroy-1.2.0.tgz#4803735509ad8be552934c67df614f94e66fa015" + integrity sha512-2sJGJTaXIIaR1w4iJSNoN0hnMY7Gpc/n8D4qSCJw8QqFWXf7cuAgnEHxBpweaVcPevC2l3KpjYCx3NypQQgaJg== + +detect-node@^2.0.4: + version "2.1.0" + resolved "https://registry.yarnpkg.com/detect-node/-/detect-node-2.1.0.tgz#c9c70775a49c3d03bc2c06d9a73be550f978f8b1" + integrity sha512-T0NIuQpnTvFDATNuHN5roPwSBG83rFsuO+MXXH9/3N1eFbn4wcPjttvjMLEPWJ0RGUYgQE7cGgS3tNxbqCGM7g== + +detect-port-alt@^1.1.6: + version "1.1.6" + resolved "https://registry.yarnpkg.com/detect-port-alt/-/detect-port-alt-1.1.6.tgz#24707deabe932d4a3cf621302027c2b266568275" + integrity sha512-5tQykt+LqfJFBEYaDITx7S7cR7mJ/zQmLXZ2qt5w04ainYZw6tBf9dBunMjVeVOdYVRUzUOE4HkY5J7+uttb5Q== + dependencies: + address "^1.0.1" + debug "^2.6.0" + +detect-port@^1.5.1: + version "1.5.1" + resolved "https://registry.yarnpkg.com/detect-port/-/detect-port-1.5.1.tgz#451ca9b6eaf20451acb0799b8ab40dff7718727b" + integrity sha512-aBzdj76lueB6uUst5iAs7+0H/oOjqI5D16XUWxlWMIMROhcM0rfsNVk93zTngq1dDNpoXRr++Sus7ETAExppAQ== + dependencies: + address "^1.0.1" + debug "4" + +devlop@^1.0.0, devlop@^1.1.0: + version "1.1.0" + resolved "https://registry.yarnpkg.com/devlop/-/devlop-1.1.0.tgz#4db7c2ca4dc6e0e834c30be70c94bbc976dc7018" + integrity sha512-RWmIqhcFf1lRYBvNmr7qTNuyCt/7/ns2jbpp1+PalgE/rDQcBT0fioSMUpJ93irlUhC5hrg4cYqe6U+0ImW0rA== + dependencies: + dequal "^2.0.0" + +dir-glob@^3.0.1: + version "3.0.1" + resolved "https://registry.yarnpkg.com/dir-glob/-/dir-glob-3.0.1.tgz#56dbf73d992a4a93ba1584f4534063fd2e41717f" + integrity sha512-WkrWp9GR4KXfKGYzOLmTuGVi1UWFfws377n9cc55/tb6DuqyF6pcQ5AbiHEshaDpY9v6oaSr2XCDidGmMwdzIA== + dependencies: + path-type "^4.0.0" + +dns-equal@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/dns-equal/-/dns-equal-1.0.0.tgz#b39e7f1da6eb0a75ba9c17324b34753c47e0654d" + integrity sha512-z+paD6YUQsk+AbGCEM4PrOXSss5gd66QfcVBFTKR/HpFL9jCqikS94HYwKww6fQyO7IxrIIyUu+g0Ka9tUS2Cg== + +dns-packet@^5.2.2: + version "5.6.1" + resolved "https://registry.yarnpkg.com/dns-packet/-/dns-packet-5.6.1.tgz#ae888ad425a9d1478a0674256ab866de1012cf2f" + integrity sha512-l4gcSouhcgIKRvyy99RNVOgxXiicE+2jZoNmaNmZ6JXiGajBOJAesk1OBlJuM5k2c+eudGdLxDqXuPCKIj6kpw== + dependencies: + "@leichtgewicht/ip-codec" "^2.0.1" + +docusaurus-plugin-typedoc@^0.21.0: + version "0.21.0" + resolved "https://registry.yarnpkg.com/docusaurus-plugin-typedoc/-/docusaurus-plugin-typedoc-0.21.0.tgz#b65b87acc40689f0fc8ba3aea0420af5fae2ebbb" + integrity sha512-7DLFrf0JP+L5vSRQHVKIbndjbksd2MlxPqNmmdxzLFiRINgrY23s9waduWM9t24PUsf5JZ0tlGKlE3sK4uZ72Q== + +dom-converter@^0.2.0: + version "0.2.0" + resolved "https://registry.yarnpkg.com/dom-converter/-/dom-converter-0.2.0.tgz#6721a9daee2e293682955b6afe416771627bb768" + integrity sha512-gd3ypIPfOMr9h5jIKq8E3sHOTCjeirnl0WK5ZdS1AW0Odt0b1PaWaHdJ4Qk4klv+YB9aJBS7mESXjFoDQPu6DA== + dependencies: + utila "~0.4" + +dom-serializer@^1.0.1: + version "1.4.1" + resolved "https://registry.yarnpkg.com/dom-serializer/-/dom-serializer-1.4.1.tgz#de5d41b1aea290215dc45a6dae8adcf1d32e2d30" + integrity sha512-VHwB3KfrcOOkelEG2ZOfxqLZdfkil8PtJi4P8N2MMXucZq2yLp75ClViUlOVwyoHEDjYU433Aq+5zWP61+RGag== + dependencies: + domelementtype "^2.0.1" + domhandler "^4.2.0" + entities "^2.0.0" + +dom-serializer@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/dom-serializer/-/dom-serializer-2.0.0.tgz#e41b802e1eedf9f6cae183ce5e622d789d7d8e53" + integrity sha512-wIkAryiqt/nV5EQKqQpo3SToSOV9J0DnbJqwK7Wv/Trc92zIAYZ4FlMu+JPFW1DfGFt81ZTCGgDEabffXeLyJg== + dependencies: + domelementtype "^2.3.0" + domhandler "^5.0.2" + entities "^4.2.0" + +domelementtype@^2.0.1, domelementtype@^2.2.0, domelementtype@^2.3.0: + version "2.3.0" + resolved "https://registry.yarnpkg.com/domelementtype/-/domelementtype-2.3.0.tgz#5c45e8e869952626331d7aab326d01daf65d589d" + integrity sha512-OLETBj6w0OsagBwdXnPdN0cnMfF9opN69co+7ZrbfPGrdpPVNBUj02spi6B1N7wChLQiPn4CSH/zJvXw56gmHw== + +domhandler@^4.0.0, domhandler@^4.2.0, domhandler@^4.3.1: + version "4.3.1" + resolved "https://registry.yarnpkg.com/domhandler/-/domhandler-4.3.1.tgz#8d792033416f59d68bc03a5aa7b018c1ca89279c" + integrity sha512-GrwoxYN+uWlzO8uhUXRl0P+kHE4GtVPfYzVLcUxPL7KNdHKj66vvlhiweIHqYYXWlw+T8iLMp42Lm67ghw4WMQ== + dependencies: + domelementtype "^2.2.0" + +domhandler@^5.0.2, domhandler@^5.0.3: + version "5.0.3" + resolved "https://registry.yarnpkg.com/domhandler/-/domhandler-5.0.3.tgz#cc385f7f751f1d1fc650c21374804254538c7d31" + integrity sha512-cgwlv/1iFQiFnU96XXgROh8xTeetsnJiDsTc7TYCLFd9+/WNkIqPTxiM/8pSd8VIrhXGTf1Ny1q1hquVqDJB5w== + dependencies: + domelementtype "^2.3.0" + +domutils@^2.5.2, domutils@^2.8.0: + version "2.8.0" + resolved "https://registry.yarnpkg.com/domutils/-/domutils-2.8.0.tgz#4437def5db6e2d1f5d6ee859bd95ca7d02048135" + integrity sha512-w96Cjofp72M5IIhpjgobBimYEfoPjx1Vx0BSX9P30WBdZW2WIKU0T1Bd0kz2eNZ9ikjKgHbEyKx8BB6H1L3h3A== + dependencies: + dom-serializer "^1.0.1" + domelementtype "^2.2.0" + domhandler "^4.2.0" + +domutils@^3.0.1: + version "3.1.0" + resolved "https://registry.yarnpkg.com/domutils/-/domutils-3.1.0.tgz#c47f551278d3dc4b0b1ab8cbb42d751a6f0d824e" + integrity sha512-H78uMmQtI2AhgDJjWeQmHwJJ2bLPD3GMmO7Zja/ZZh84wkm+4ut+IUnUdRa8uCGX88DiVx1j6FRe1XfxEgjEZA== + dependencies: + dom-serializer "^2.0.0" + domelementtype "^2.3.0" + domhandler "^5.0.3" + +dot-case@^3.0.4: + version "3.0.4" + resolved "https://registry.yarnpkg.com/dot-case/-/dot-case-3.0.4.tgz#9b2b670d00a431667a8a75ba29cd1b98809ce751" + integrity sha512-Kv5nKlh6yRrdrGvxeJ2e5y2eRUpkUosIW4A2AS38zwSz27zu7ufDwQPi5Jhs3XAlGNetl3bmnGhQsMtkKJnj3w== + dependencies: + no-case "^3.0.4" + tslib "^2.0.3" + +dot-prop@^6.0.1: + version "6.0.1" + resolved "https://registry.yarnpkg.com/dot-prop/-/dot-prop-6.0.1.tgz#fc26b3cf142b9e59b74dbd39ed66ce620c681083" + integrity sha512-tE7ztYzXHIeyvc7N+hR3oi7FIbf/NIjVP9hmAt3yMXzrQ072/fpjGLx2GxNxGxUl5V73MEqYzioOMoVhGMJ5cA== + dependencies: + is-obj "^2.0.0" + +duplexer@^0.1.2: + version "0.1.2" + resolved "https://registry.yarnpkg.com/duplexer/-/duplexer-0.1.2.tgz#3abe43aef3835f8ae077d136ddce0f276b0400e6" + integrity sha512-jtD6YG370ZCIi/9GTaJKQxWTZD045+4R4hTk/x1UyoqadyJ9x9CgSi1RlVDQF8U2sxLLSnFkCaMihqljHIWgMg== + +eastasianwidth@^0.2.0: + version "0.2.0" + resolved "https://registry.yarnpkg.com/eastasianwidth/-/eastasianwidth-0.2.0.tgz#696ce2ec0aa0e6ea93a397ffcf24aa7840c827cb" + integrity sha512-I88TYZWc9XiYHRQ4/3c5rjjfgkjhLyW2luGIheGERbNQ6OY7yTybanSpDXZa8y7VUP9YmDcYa+eyq4ca7iLqWA== + +ee-first@1.1.1: + version "1.1.1" + resolved "https://registry.yarnpkg.com/ee-first/-/ee-first-1.1.1.tgz#590c61156b0ae2f4f0255732a158b266bc56b21d" + integrity sha512-WMwm9LhRUo+WUaRN+vRuETqG89IgZphVSNkdFgeb6sS/E4OrDIN7t48CAewSHXc6C8lefD8KKfr5vY61brQlow== + +electron-to-chromium@^1.4.535: + version "1.4.596" + resolved "https://registry.yarnpkg.com/electron-to-chromium/-/electron-to-chromium-1.4.596.tgz#6752d1aa795d942d49dfc5d3764d6ea283fab1d7" + integrity sha512-zW3zbZ40Icb2BCWjm47nxwcFGYlIgdXkAx85XDO7cyky9J4QQfq8t0W19/TLZqq3JPQXtlv8BPIGmfa9Jb4scg== + +emoji-regex@^8.0.0: + version "8.0.0" + resolved "https://registry.yarnpkg.com/emoji-regex/-/emoji-regex-8.0.0.tgz#e818fd69ce5ccfcb404594f842963bf53164cc37" + integrity sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A== + +emoji-regex@^9.2.2: + version "9.2.2" + resolved "https://registry.yarnpkg.com/emoji-regex/-/emoji-regex-9.2.2.tgz#840c8803b0d8047f4ff0cf963176b32d4ef3ed72" + integrity sha512-L18DaJsXSUk2+42pv8mLs5jJT2hqFkFE4j21wOmgbUqsZ2hL72NsUU785g9RXgo3s0ZNgVl42TiHp3ZtOv/Vyg== + +emojilib@^2.4.0: + version "2.4.0" + resolved "https://registry.yarnpkg.com/emojilib/-/emojilib-2.4.0.tgz#ac518a8bb0d5f76dda57289ccb2fdf9d39ae721e" + integrity sha512-5U0rVMU5Y2n2+ykNLQqMoqklN9ICBT/KsvC1Gz6vqHbz2AXXGkG+Pm5rMWk/8Vjrr/mY9985Hi8DYzn1F09Nyw== + +emojis-list@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/emojis-list/-/emojis-list-3.0.0.tgz#5570662046ad29e2e916e71aae260abdff4f6a78" + integrity sha512-/kyM18EfinwXZbno9FyUGeFh87KC8HRQBQGildHZbEuRyWFOmv1U10o9BBp8XVZDVNNuQKyIGIu5ZYAAXJ0V2Q== + +emoticon@^4.0.1: + version "4.0.1" + resolved "https://registry.yarnpkg.com/emoticon/-/emoticon-4.0.1.tgz#2d2bbbf231ce3a5909e185bbb64a9da703a1e749" + integrity sha512-dqx7eA9YaqyvYtUhJwT4rC1HIp82j5ybS1/vQ42ur+jBe17dJMwZE4+gvL1XadSFfxaPFFGt3Xsw+Y8akThDlw== + +encodeurl@~1.0.2: + version "1.0.2" + resolved "https://registry.yarnpkg.com/encodeurl/-/encodeurl-1.0.2.tgz#ad3ff4c86ec2d029322f5a02c3a9a606c95b3f59" + integrity sha512-TPJXq8JqFaVYm2CWmPvnP2Iyo4ZSM7/QKcSmuMLDObfpH5fi7RUGmd/rTDf+rut/saiDiQEeVTNgAmJEdAOx0w== + +enhanced-resolve@^5.15.0: + version "5.15.0" + resolved "https://registry.yarnpkg.com/enhanced-resolve/-/enhanced-resolve-5.15.0.tgz#1af946c7d93603eb88e9896cee4904dc012e9c35" + integrity sha512-LXYT42KJ7lpIKECr2mAXIaMldcNCh/7E0KBKOu4KSfkHmP+mZmSs+8V5gBAqisWBy0OO4W5Oyys0GO1Y8KtdKg== + dependencies: + graceful-fs "^4.2.4" + tapable "^2.2.0" + +entities@^2.0.0: + version "2.2.0" + resolved "https://registry.yarnpkg.com/entities/-/entities-2.2.0.tgz#098dc90ebb83d8dffa089d55256b351d34c4da55" + integrity sha512-p92if5Nz619I0w+akJrLZH0MX0Pb5DX39XOwQTtXSdQQOaYH03S1uIQp4mhOZtAXrxq4ViO67YTiLBo2638o9A== + +entities@^4.2.0, entities@^4.4.0: + version "4.5.0" + resolved "https://registry.yarnpkg.com/entities/-/entities-4.5.0.tgz#5d268ea5e7113ec74c4d033b79ea5a35a488fb48" + integrity sha512-V0hjH4dGPh9Ao5p0MoRY6BVqtwCjhz6vI5LT8AJ55H+4g9/4vbHx1I54fS0XuclLhDHArPQCiMjDxjaL8fPxhw== + +error-ex@^1.3.1: + version "1.3.2" + resolved "https://registry.yarnpkg.com/error-ex/-/error-ex-1.3.2.tgz#b4ac40648107fdcdcfae242f428bea8a14d4f1bf" + integrity sha512-7dFHNmqeFSEt2ZBsCriorKnn3Z2pj+fd9kmI6QoWw4//DL+icEBfc0U7qJCisqrTsKTjw4fNFy2pW9OqStD84g== + dependencies: + is-arrayish "^0.2.1" + +es-module-lexer@^1.2.1: + version "1.4.1" + resolved "https://registry.yarnpkg.com/es-module-lexer/-/es-module-lexer-1.4.1.tgz#41ea21b43908fe6a287ffcbe4300f790555331f5" + integrity sha512-cXLGjP0c4T3flZJKQSuziYoq7MlT+rnvfZjfp7h+I7K9BNX54kP9nyWvdbwjQ4u1iWbOL4u96fgeZLToQlZC7w== + +escalade@^3.1.1: + version "3.1.1" + resolved "https://registry.yarnpkg.com/escalade/-/escalade-3.1.1.tgz#d8cfdc7000965c5a0174b4a82eaa5c0552742e40" + integrity sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw== + +escape-goat@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/escape-goat/-/escape-goat-4.0.0.tgz#9424820331b510b0666b98f7873fe11ac4aa8081" + integrity sha512-2Sd4ShcWxbx6OY1IHyla/CVNwvg7XwZVoXZHcSu9w9SReNP1EzzD5T8NWKIR38fIqEns9kDWKUQTXXAmlDrdPg== + +escape-html@^1.0.3, escape-html@~1.0.3: + version "1.0.3" + resolved "https://registry.yarnpkg.com/escape-html/-/escape-html-1.0.3.tgz#0258eae4d3d0c0974de1c169188ef0051d1d1988" + integrity sha512-NiSupZ4OeuGwr68lGIeym/ksIZMJodUGOSCZ/FSnTxcrekbvqrgdUxlJOMpijaKZVjAJrWrGs/6Jy8OMuyj9ow== + +escape-string-regexp@^1.0.5: + version "1.0.5" + resolved "https://registry.yarnpkg.com/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz#1b61c0562190a8dff6ae3bb2cf0200ca130b86d4" + integrity sha512-vbRorB5FUQWvla16U8R/qgaFIya2qGzwDrNmCZuYKrbdSUMG6I1ZCGQRefkRVhuOkIGVne7BQ35DSfo1qvJqFg== + +escape-string-regexp@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz#14ba83a5d373e3d311e5afca29cf5bfad965bf34" + integrity sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA== + +escape-string-regexp@^5.0.0: + version "5.0.0" + resolved "https://registry.yarnpkg.com/escape-string-regexp/-/escape-string-regexp-5.0.0.tgz#4683126b500b61762f2dbebace1806e8be31b1c8" + integrity sha512-/veY75JbMK4j1yjvuUxuVsiS/hr/4iHs9FTT6cgTexxdE0Ly/glccBAkloH/DofkjRbZU3bnoj38mOmhkZ0lHw== + +eslint-scope@5.1.1: + version "5.1.1" + resolved "https://registry.yarnpkg.com/eslint-scope/-/eslint-scope-5.1.1.tgz#e786e59a66cb92b3f6c1fb0d508aab174848f48c" + integrity sha512-2NxwbF/hZ0KpepYN0cNbo+FN6XoK7GaHlQhgx/hIZl6Va0bF45RQOOwhLIy8lQDbuCiadSLCBnH2CFYquit5bw== + dependencies: + esrecurse "^4.3.0" + estraverse "^4.1.1" + +esprima@^4.0.0: + version "4.0.1" + resolved "https://registry.yarnpkg.com/esprima/-/esprima-4.0.1.tgz#13b04cdb3e6c5d19df91ab6987a8695619b0aa71" + integrity sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A== + +esrecurse@^4.3.0: + version "4.3.0" + resolved "https://registry.yarnpkg.com/esrecurse/-/esrecurse-4.3.0.tgz#7ad7964d679abb28bee72cec63758b1c5d2c9921" + integrity sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag== + dependencies: + estraverse "^5.2.0" + +estraverse@^4.1.1: + version "4.3.0" + resolved "https://registry.yarnpkg.com/estraverse/-/estraverse-4.3.0.tgz#398ad3f3c5a24948be7725e83d11a7de28cdbd1d" + integrity sha512-39nnKffWz8xN1BU/2c79n9nB9HDzo0niYUqx6xyqUnyoAnQyyWpOTdZEeiCch8BBu515t4wp9ZmgVfVhn9EBpw== + +estraverse@^5.2.0: + version "5.3.0" + resolved "https://registry.yarnpkg.com/estraverse/-/estraverse-5.3.0.tgz#2eea5290702f26ab8fe5370370ff86c965d21123" + integrity sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA== + +estree-util-attach-comments@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/estree-util-attach-comments/-/estree-util-attach-comments-3.0.0.tgz#344bde6a64c8a31d15231e5ee9e297566a691c2d" + integrity sha512-cKUwm/HUcTDsYh/9FgnuFqpfquUbwIqwKM26BVCGDPVgvaCl/nDCCjUfiLlx6lsEZ3Z4RFxNbOQ60pkaEwFxGw== + dependencies: + "@types/estree" "^1.0.0" + +estree-util-build-jsx@^3.0.0: + version "3.0.1" + resolved "https://registry.yarnpkg.com/estree-util-build-jsx/-/estree-util-build-jsx-3.0.1.tgz#b6d0bced1dcc4f06f25cf0ceda2b2dcaf98168f1" + integrity sha512-8U5eiL6BTrPxp/CHbs2yMgP8ftMhR5ww1eIKoWRMlqvltHF8fZn5LRDvTKuxD3DUn+shRbLGqXemcP51oFCsGQ== + dependencies: + "@types/estree-jsx" "^1.0.0" + devlop "^1.0.0" + estree-util-is-identifier-name "^3.0.0" + estree-walker "^3.0.0" + +estree-util-is-identifier-name@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/estree-util-is-identifier-name/-/estree-util-is-identifier-name-3.0.0.tgz#0b5ef4c4ff13508b34dcd01ecfa945f61fce5dbd" + integrity sha512-hFtqIDZTIUZ9BXLb8y4pYGyk6+wekIivNVTcmvk8NoOh+VeRn5y6cEHzbURrWbfp1fIqdVipilzj+lfaadNZmg== + +estree-util-to-js@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/estree-util-to-js/-/estree-util-to-js-2.0.0.tgz#10a6fb924814e6abb62becf0d2bc4dea51d04f17" + integrity sha512-WDF+xj5rRWmD5tj6bIqRi6CkLIXbbNQUcxQHzGysQzvHmdYG2G7p/Tf0J0gpxGgkeMZNTIjT/AoSvC9Xehcgdg== + dependencies: + "@types/estree-jsx" "^1.0.0" + astring "^1.8.0" + source-map "^0.7.0" + +estree-util-value-to-estree@^3.0.1: + version "3.0.1" + resolved "https://registry.yarnpkg.com/estree-util-value-to-estree/-/estree-util-value-to-estree-3.0.1.tgz#0b7b5d6b6a4aaad5c60999ffbc265a985df98ac5" + integrity sha512-b2tdzTurEIbwRh+mKrEcaWfu1wgb8J1hVsgREg7FFiecWwK/PhO8X0kyc+0bIcKNtD4sqxIdNoRy6/p/TvECEA== + dependencies: + "@types/estree" "^1.0.0" + is-plain-obj "^4.0.0" + +estree-util-visit@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/estree-util-visit/-/estree-util-visit-2.0.0.tgz#13a9a9f40ff50ed0c022f831ddf4b58d05446feb" + integrity sha512-m5KgiH85xAhhW8Wta0vShLcUvOsh3LLPI2YVwcbio1l7E09NTLL1EyMZFM1OyWowoH0skScNbhOPl4kcBgzTww== + dependencies: + "@types/estree-jsx" "^1.0.0" + "@types/unist" "^3.0.0" + +estree-walker@^3.0.0: + version "3.0.3" + resolved "https://registry.yarnpkg.com/estree-walker/-/estree-walker-3.0.3.tgz#67c3e549ec402a487b4fc193d1953a524752340d" + integrity sha512-7RUKfXgSMMkzt6ZuXmqapOurLGPPfgj6l9uRZ7lRGolvk0y2yocc35LdcxKC5PQZdn2DMqioAQ2NoWcrTKmm6g== + dependencies: + "@types/estree" "^1.0.0" + +esutils@^2.0.2: + version "2.0.3" + resolved "https://registry.yarnpkg.com/esutils/-/esutils-2.0.3.tgz#74d2eb4de0b8da1293711910d50775b9b710ef64" + integrity sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g== + +eta@^2.2.0: + version "2.2.0" + resolved "https://registry.yarnpkg.com/eta/-/eta-2.2.0.tgz#eb8b5f8c4e8b6306561a455e62cd7492fe3a9b8a" + integrity sha512-UVQ72Rqjy/ZKQalzV5dCCJP80GrmPrMxh6NlNf+erV6ObL0ZFkhCstWRawS85z3smdr3d2wXPsZEY7rDPfGd2g== + +etag@~1.8.1: + version "1.8.1" + resolved "https://registry.yarnpkg.com/etag/-/etag-1.8.1.tgz#41ae2eeb65efa62268aebfea83ac7d79299b0887" + integrity sha512-aIL5Fx7mawVa300al2BnEE4iNvo1qETxLrPI/o05L7z6go7fCw1J6EQmbK4FmJ2AS7kgVF/KEZWufBfdClMcPg== + +eval@^0.1.8: + version "0.1.8" + resolved "https://registry.yarnpkg.com/eval/-/eval-0.1.8.tgz#2b903473b8cc1d1989b83a1e7923f883eb357f85" + integrity sha512-EzV94NYKoO09GLXGjXj9JIlXijVck4ONSr5wiCWDvhsvj5jxSrzTmRU/9C1DyB6uToszLs8aifA6NQ7lEQdvFw== + dependencies: + "@types/node" "*" + require-like ">= 0.1.1" + +eventemitter3@^4.0.0: + version "4.0.7" + resolved "https://registry.yarnpkg.com/eventemitter3/-/eventemitter3-4.0.7.tgz#2de9b68f6528d5644ef5c59526a1b4a07306169f" + integrity sha512-8guHBZCwKnFhYdHr2ysuRWErTwhoN2X8XELRlrRwpmfeY2jjuUN4taQMsULKUVo1K4DvZl+0pgfyoysHxvmvEw== + +events@^3.2.0: + version "3.3.0" + resolved "https://registry.yarnpkg.com/events/-/events-3.3.0.tgz#31a95ad0a924e2d2c419a813aeb2c4e878ea7400" + integrity sha512-mQw+2fkQbALzQ7V0MY0IqdnXNOeTtP4r0lN9z7AAawCXgqea7bDii20AYrIBrFd/Hx0M2Ocz6S111CaFkUcb0Q== + +execa@^5.0.0: + version "5.1.1" + resolved "https://registry.yarnpkg.com/execa/-/execa-5.1.1.tgz#f80ad9cbf4298f7bd1d4c9555c21e93741c411dd" + integrity sha512-8uSpZZocAZRBAPIEINJj3Lo9HyGitllczc27Eh5YYojjMFMn8yHMDMaUHE2Jqfq05D/wucwI4JGURyXt1vchyg== + dependencies: + cross-spawn "^7.0.3" + get-stream "^6.0.0" + human-signals "^2.1.0" + is-stream "^2.0.0" + merge-stream "^2.0.0" + npm-run-path "^4.0.1" + onetime "^5.1.2" + signal-exit "^3.0.3" + strip-final-newline "^2.0.0" + +express@^4.17.3: + version "4.18.2" + resolved "https://registry.yarnpkg.com/express/-/express-4.18.2.tgz#3fabe08296e930c796c19e3c516979386ba9fd59" + integrity sha512-5/PsL6iGPdfQ/lKM1UuielYgv3BUoJfz1aUwU9vHZ+J7gyvwdQXFEBIEIaxeGf0GIcreATNyBExtalisDbuMqQ== + dependencies: + accepts "~1.3.8" + array-flatten "1.1.1" + body-parser "1.20.1" + content-disposition "0.5.4" + content-type "~1.0.4" + cookie "0.5.0" + cookie-signature "1.0.6" + debug "2.6.9" + depd "2.0.0" + encodeurl "~1.0.2" + escape-html "~1.0.3" + etag "~1.8.1" + finalhandler "1.2.0" + fresh "0.5.2" + http-errors "2.0.0" + merge-descriptors "1.0.1" + methods "~1.1.2" + on-finished "2.4.1" + parseurl "~1.3.3" + path-to-regexp "0.1.7" + proxy-addr "~2.0.7" + qs "6.11.0" + range-parser "~1.2.1" + safe-buffer "5.2.1" + send "0.18.0" + serve-static "1.15.0" + setprototypeof "1.2.0" + statuses "2.0.1" + type-is "~1.6.18" + utils-merge "1.0.1" + vary "~1.1.2" + +extend-shallow@^2.0.1: + version "2.0.1" + resolved "https://registry.yarnpkg.com/extend-shallow/-/extend-shallow-2.0.1.tgz#51af7d614ad9a9f610ea1bafbb989d6b1c56890f" + integrity sha512-zCnTtlxNoAiDc3gqY2aYAWFx7XWWiasuF2K8Me5WbN8otHKTUKBwjPtNpRs/rbUZm7KxWAaNj7P1a/p52GbVug== + dependencies: + is-extendable "^0.1.0" + +extend@^3.0.0: + version "3.0.2" + resolved "https://registry.yarnpkg.com/extend/-/extend-3.0.2.tgz#f8b1136b4071fbd8eb140aff858b1019ec2915fa" + integrity sha512-fjquC59cD7CyW6urNXK0FBufkZcoiGG80wTuPujX590cB5Ttln20E2UB4S/WARVqhXffZl2LNgS+gQdPIIim/g== + +fast-deep-equal@^3.1.1, fast-deep-equal@^3.1.3: + version "3.1.3" + resolved "https://registry.yarnpkg.com/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz#3a7d56b559d6cbc3eb512325244e619a65c6c525" + integrity sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q== + +fast-glob@^3.2.11, fast-glob@^3.2.9, fast-glob@^3.3.0: + version "3.3.2" + resolved "https://registry.yarnpkg.com/fast-glob/-/fast-glob-3.3.2.tgz#a904501e57cfdd2ffcded45e99a54fef55e46129" + integrity sha512-oX2ruAFQwf/Orj8m737Y5adxDQO0LAB7/S5MnxCdTNDd4p6BsyIVsv9JQsATbTSq8KHRpLwIHbVlUNatxd+1Ow== + dependencies: + "@nodelib/fs.stat" "^2.0.2" + "@nodelib/fs.walk" "^1.2.3" + glob-parent "^5.1.2" + merge2 "^1.3.0" + micromatch "^4.0.4" + +fast-json-stable-stringify@^2.0.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz#874bf69c6f404c2b5d99c481341399fd55892633" + integrity sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw== + +fast-url-parser@1.1.3: + version "1.1.3" + resolved "https://registry.yarnpkg.com/fast-url-parser/-/fast-url-parser-1.1.3.tgz#f4af3ea9f34d8a271cf58ad2b3759f431f0b318d" + integrity sha512-5jOCVXADYNuRkKFzNJ0dCCewsZiYo0dz8QNYljkOpFC6r2U4OBmKtvm/Tsuh4w1YYdDqDb31a8TVhBJ2OJKdqQ== + dependencies: + punycode "^1.3.2" + +fastq@^1.6.0: + version "1.15.0" + resolved "https://registry.yarnpkg.com/fastq/-/fastq-1.15.0.tgz#d04d07c6a2a68fe4599fea8d2e103a937fae6b3a" + integrity sha512-wBrocU2LCXXa+lWBt8RoIRD89Fi8OdABODa/kEnyeyjS5aZO5/GNvI5sEINADqP/h8M29UHTHUb53sUu5Ihqdw== + dependencies: + reusify "^1.0.4" + +fault@^2.0.0: + version "2.0.1" + resolved "https://registry.yarnpkg.com/fault/-/fault-2.0.1.tgz#d47ca9f37ca26e4bd38374a7c500b5a384755b6c" + integrity sha512-WtySTkS4OKev5JtpHXnib4Gxiurzh5NCGvWrFaZ34m6JehfTUhKZvn9njTfw48t6JumVQOmrKqpmGcdwxnhqBQ== + dependencies: + format "^0.2.0" + +faye-websocket@^0.11.3: + version "0.11.4" + resolved "https://registry.yarnpkg.com/faye-websocket/-/faye-websocket-0.11.4.tgz#7f0d9275cfdd86a1c963dc8b65fcc451edcbb1da" + integrity sha512-CzbClwlXAuiRQAlUyfqPgvPoNKTckTPGfwZV4ZdAhVcP2lh9KUxJg2b5GkE7XbjKQ3YJnQ9z6D9ntLAlB+tP8g== + dependencies: + websocket-driver ">=0.5.1" + +fbemitter@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/fbemitter/-/fbemitter-3.0.0.tgz#00b2a1af5411254aab416cd75f9e6289bee4bff3" + integrity sha512-KWKaceCwKQU0+HPoop6gn4eOHk50bBv/VxjJtGMfwmJt3D29JpN4H4eisCtIPA+a8GVBam+ldMMpMjJUvpDyHw== + dependencies: + fbjs "^3.0.0" + +fbjs-css-vars@^1.0.0: + version "1.0.2" + resolved "https://registry.yarnpkg.com/fbjs-css-vars/-/fbjs-css-vars-1.0.2.tgz#216551136ae02fe255932c3ec8775f18e2c078b8" + integrity sha512-b2XGFAFdWZWg0phtAWLHCk836A1Xann+I+Dgd3Gk64MHKZO44FfoD1KxyvbSh0qZsIoXQGGlVztIY+oitJPpRQ== + +fbjs@^3.0.0, fbjs@^3.0.1: + version "3.0.5" + resolved "https://registry.yarnpkg.com/fbjs/-/fbjs-3.0.5.tgz#aa0edb7d5caa6340011790bd9249dbef8a81128d" + integrity sha512-ztsSx77JBtkuMrEypfhgc3cI0+0h+svqeie7xHbh1k/IKdcydnvadp/mUaGgjAOXQmQSxsqgaRhS3q9fy+1kxg== + dependencies: + cross-fetch "^3.1.5" + fbjs-css-vars "^1.0.0" + loose-envify "^1.0.0" + object-assign "^4.1.0" + promise "^7.1.1" + setimmediate "^1.0.5" + ua-parser-js "^1.0.35" + +feed@^4.2.2: + version "4.2.2" + resolved "https://registry.yarnpkg.com/feed/-/feed-4.2.2.tgz#865783ef6ed12579e2c44bbef3c9113bc4956a7e" + integrity sha512-u5/sxGfiMfZNtJ3OvQpXcvotFpYkL0n9u9mM2vkui2nGo8b4wvDkJ8gAkYqbA8QpGyFCv3RK0Z+Iv+9veCS9bQ== + dependencies: + xml-js "^1.6.11" + +file-loader@^6.2.0: + version "6.2.0" + resolved "https://registry.yarnpkg.com/file-loader/-/file-loader-6.2.0.tgz#baef7cf8e1840df325e4390b4484879480eebe4d" + integrity sha512-qo3glqyTa61Ytg4u73GultjHGjdRyig3tG6lPtyX/jOEJvHif9uB0/OCI2Kif6ctF3caQTW2G5gym21oAsI4pw== + dependencies: + loader-utils "^2.0.0" + schema-utils "^3.0.0" + +filesize@^8.0.6: + version "8.0.7" + resolved "https://registry.yarnpkg.com/filesize/-/filesize-8.0.7.tgz#695e70d80f4e47012c132d57a059e80c6b580bd8" + integrity sha512-pjmC+bkIF8XI7fWaH8KxHcZL3DPybs1roSKP4rKDvy20tAWwIObE4+JIseG2byfGKhud5ZnM4YSGKBz7Sh0ndQ== + +fill-range@^7.0.1: + version "7.0.1" + resolved "https://registry.yarnpkg.com/fill-range/-/fill-range-7.0.1.tgz#1919a6a7c75fe38b2c7c77e5198535da9acdda40" + integrity sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ== + dependencies: + to-regex-range "^5.0.1" + +finalhandler@1.2.0: + version "1.2.0" + resolved "https://registry.yarnpkg.com/finalhandler/-/finalhandler-1.2.0.tgz#7d23fe5731b207b4640e4fcd00aec1f9207a7b32" + integrity sha512-5uXcUVftlQMFnWC9qu/svkWv3GTd2PfUhK/3PLkYNAe7FbqJMt3515HaxE6eRL74GdsriiwujiawdaB1BpEISg== + dependencies: + debug "2.6.9" + encodeurl "~1.0.2" + escape-html "~1.0.3" + on-finished "2.4.1" + parseurl "~1.3.3" + statuses "2.0.1" + unpipe "~1.0.0" + +find-cache-dir@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/find-cache-dir/-/find-cache-dir-4.0.0.tgz#a30ee0448f81a3990708f6453633c733e2f6eec2" + integrity sha512-9ZonPT4ZAK4a+1pUPVPZJapbi7O5qbbJPdYw/NOQWZZbVLdDTYM3A4R9z/DpAM08IDaFGsvPgiGZ82WEwUDWjg== + dependencies: + common-path-prefix "^3.0.0" + pkg-dir "^7.0.0" + +find-up@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/find-up/-/find-up-3.0.0.tgz#49169f1d7993430646da61ecc5ae355c21c97b73" + integrity sha512-1yD6RmLI1XBfxugvORwlck6f75tYL+iR0jqwsOrOxMZyGYqUuDhJ0l4AXdO1iX/FTs9cBAMEk1gWSEx1kSbylg== + dependencies: + locate-path "^3.0.0" + +find-up@^5.0.0: + version "5.0.0" + resolved "https://registry.yarnpkg.com/find-up/-/find-up-5.0.0.tgz#4c92819ecb7083561e4f4a240a86be5198f536fc" + integrity sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng== + dependencies: + locate-path "^6.0.0" + path-exists "^4.0.0" + +find-up@^6.3.0: + version "6.3.0" + resolved "https://registry.yarnpkg.com/find-up/-/find-up-6.3.0.tgz#2abab3d3280b2dc7ac10199ef324c4e002c8c790" + integrity sha512-v2ZsoEuVHYy8ZIlYqwPe/39Cy+cFDzp4dXPaxNvkEuouymu+2Jbz0PxpKarJHYJTmv2HWT3O382qY8l4jMWthw== + dependencies: + locate-path "^7.1.0" + path-exists "^5.0.0" + +flat@^5.0.2: + version "5.0.2" + resolved "https://registry.yarnpkg.com/flat/-/flat-5.0.2.tgz#8ca6fe332069ffa9d324c327198c598259ceb241" + integrity sha512-b6suED+5/3rTpUBdG1gupIl8MPFCAMA0QXwmljLhvCUKcUvdE4gWky9zpuGCcXHOsz4J9wPGNWq6OKpmIzz3hQ== + +flux@~4.0.1: + version "4.0.4" + resolved "https://registry.yarnpkg.com/flux/-/flux-4.0.4.tgz#9661182ea81d161ee1a6a6af10d20485ef2ac572" + integrity sha512-NCj3XlayA2UsapRpM7va6wU1+9rE5FIL7qoMcmxWHRzbp0yujihMBm9BBHZ1MDIk5h5o2Bl6eGiCe8rYELAmYw== + dependencies: + fbemitter "^3.0.0" + fbjs "^3.0.1" + +follow-redirects@^1.0.0, follow-redirects@^1.15.0: + version "1.15.3" + resolved "https://registry.yarnpkg.com/follow-redirects/-/follow-redirects-1.15.3.tgz#fe2f3ef2690afce7e82ed0b44db08165b207123a" + integrity sha512-1VzOtuEM8pC9SFU1E+8KfTjZyMztRsgEfwQl44z8A25uy13jSzTj6dyK2Df52iV0vgHCfBwLhDWevLn95w5v6Q== + +fork-ts-checker-webpack-plugin@^6.5.0: + version "6.5.3" + resolved "https://registry.yarnpkg.com/fork-ts-checker-webpack-plugin/-/fork-ts-checker-webpack-plugin-6.5.3.tgz#eda2eff6e22476a2688d10661688c47f611b37f3" + integrity sha512-SbH/l9ikmMWycd5puHJKTkZJKddF4iRLyW3DeZ08HTI7NGyLS38MXd/KGgeWumQO7YNQbW2u/NtPT2YowbPaGQ== + dependencies: + "@babel/code-frame" "^7.8.3" + "@types/json-schema" "^7.0.5" + chalk "^4.1.0" + chokidar "^3.4.2" + cosmiconfig "^6.0.0" + deepmerge "^4.2.2" + fs-extra "^9.0.0" + glob "^7.1.6" + memfs "^3.1.2" + minimatch "^3.0.4" + schema-utils "2.7.0" + semver "^7.3.2" + tapable "^1.0.0" + +form-data-encoder@^2.1.2: + version "2.1.4" + resolved "https://registry.yarnpkg.com/form-data-encoder/-/form-data-encoder-2.1.4.tgz#261ea35d2a70d48d30ec7a9603130fa5515e9cd5" + integrity sha512-yDYSgNMraqvnxiEXO4hi88+YZxaHC6QKzb5N84iRCTDeRO7ZALpir/lVmf/uXUhnwUr2O4HU8s/n6x+yNjQkHw== + +form-data@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/form-data/-/form-data-4.0.0.tgz#93919daeaf361ee529584b9b31664dc12c9fa452" + integrity sha512-ETEklSGi5t0QMZuiXoA/Q6vcnxcLQP5vdugSpuAyi6SVGi2clPPp+xgEhuMaHC+zGgn31Kd235W35f7Hykkaww== + dependencies: + asynckit "^0.4.0" + combined-stream "^1.0.8" + mime-types "^2.1.12" + +format@^0.2.0: + version "0.2.2" + resolved "https://registry.yarnpkg.com/format/-/format-0.2.2.tgz#d6170107e9efdc4ed30c9dc39016df942b5cb58b" + integrity sha512-wzsgA6WOq+09wrU1tsJ09udeR/YZRaeArL9e1wPbFg3GG2yDnC2ldKpxs4xunpFF9DgqCqOIra3bc1HWrJ37Ww== + +forwarded@0.2.0: + version "0.2.0" + resolved "https://registry.yarnpkg.com/forwarded/-/forwarded-0.2.0.tgz#2269936428aad4c15c7ebe9779a84bf0b2a81811" + integrity sha512-buRG0fpBtRHSTCOASe6hD258tEubFoRLb4ZNA6NxMVHNw2gOcwHo9wyablzMzOA5z9xA9L1KNjk/Nt6MT9aYow== + +fraction.js@^4.3.6: + version "4.3.7" + resolved "https://registry.yarnpkg.com/fraction.js/-/fraction.js-4.3.7.tgz#06ca0085157e42fda7f9e726e79fefc4068840f7" + integrity sha512-ZsDfxO51wGAXREY55a7la9LScWpwv9RxIrYABrlvOFBlH/ShPnrtsXeuUIfXKKOVicNxQ+o8JTbJvjS4M89yew== + +fresh@0.5.2: + version "0.5.2" + resolved "https://registry.yarnpkg.com/fresh/-/fresh-0.5.2.tgz#3d8cadd90d976569fa835ab1f8e4b23a105605a7" + integrity sha512-zJ2mQYM18rEFOudeV4GShTGIQ7RbzA7ozbU9I/XBpm7kqgMywgmylMwXHxZJmkVoYkna9d2pVXVXPdYTP9ej8Q== + +fs-extra@^11.1.1: + version "11.2.0" + resolved "https://registry.yarnpkg.com/fs-extra/-/fs-extra-11.2.0.tgz#e70e17dfad64232287d01929399e0ea7c86b0e5b" + integrity sha512-PmDi3uwK5nFuXh7XDTlVnS17xJS7vW36is2+w3xcv8SVxiB4NyATf4ctkVY5bkSjX0Y4nbvZCq1/EjtEyr9ktw== + dependencies: + graceful-fs "^4.2.0" + jsonfile "^6.0.1" + universalify "^2.0.0" + +fs-extra@^9.0.0: + version "9.1.0" + resolved "https://registry.yarnpkg.com/fs-extra/-/fs-extra-9.1.0.tgz#5954460c764a8da2094ba3554bf839e6b9a7c86d" + integrity sha512-hcg3ZmepS30/7BSFqRvoo3DOMQu7IjqxO5nCDt+zM9XWjb33Wg7ziNT+Qvqbuc3+gWpzO02JubVyk2G4Zvo1OQ== + dependencies: + at-least-node "^1.0.0" + graceful-fs "^4.2.0" + jsonfile "^6.0.1" + universalify "^2.0.0" + +fs-monkey@^1.0.4: + version "1.0.5" + resolved "https://registry.yarnpkg.com/fs-monkey/-/fs-monkey-1.0.5.tgz#fe450175f0db0d7ea758102e1d84096acb925788" + integrity sha512-8uMbBjrhzW76TYgEV27Y5E//W2f/lTFmx78P2w19FZSxarhI/798APGQyuGCwmkNxgwGRhrLfvWyLBvNtuOmew== + +fs.realpath@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/fs.realpath/-/fs.realpath-1.0.0.tgz#1504ad2523158caa40db4a2787cb01411994ea4f" + integrity sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw== + +fsevents@~2.3.2: + version "2.3.3" + resolved "https://registry.yarnpkg.com/fsevents/-/fsevents-2.3.3.tgz#cac6407785d03675a2a5e1a5305c697b347d90d6" + integrity sha512-5xoDfX+fL7faATnagmWPpbFtwh/R77WmMMqqHGS65C3vvB0YHrgF+B1YmZ3441tMj5n63k0212XNoJwzlhffQw== + +function-bind@^1.1.2: + version "1.1.2" + resolved "https://registry.yarnpkg.com/function-bind/-/function-bind-1.1.2.tgz#2c02d864d97f3ea6c8830c464cbd11ab6eab7a1c" + integrity sha512-7XHNxH7qX9xG5mIwxkhumTox/MIRNcOgDrxWsMt2pAr23WHp6MrRlN7FBSFpCpr+oVO0F744iUgR82nJMfG2SA== + +gensync@^1.0.0-beta.2: + version "1.0.0-beta.2" + resolved "https://registry.yarnpkg.com/gensync/-/gensync-1.0.0-beta.2.tgz#32a6ee76c3d7f52d46b2b1ae5d93fea8580a25e0" + integrity sha512-3hN7NaskYvMDLQY55gnW3NQ+mesEAepTqlg+VEbj7zzqEMBVNhzcGYYeqFo/TlYz6eQiFcp1HcsCZO+nGgS8zg== + +get-intrinsic@^1.0.2, get-intrinsic@^1.1.3, get-intrinsic@^1.2.1, get-intrinsic@^1.2.2: + version "1.2.2" + resolved "https://registry.yarnpkg.com/get-intrinsic/-/get-intrinsic-1.2.2.tgz#281b7622971123e1ef4b3c90fd7539306da93f3b" + integrity sha512-0gSo4ml/0j98Y3lngkFEot/zhiCeWsbYIlZ+uZOVgzLyLaUw7wxUL+nCTP0XJvJg1AXulJRI3UJi8GsbDuxdGA== + dependencies: + function-bind "^1.1.2" + has-proto "^1.0.1" + has-symbols "^1.0.3" + hasown "^2.0.0" + +get-own-enumerable-property-symbols@^3.0.0: + version "3.0.2" + resolved "https://registry.yarnpkg.com/get-own-enumerable-property-symbols/-/get-own-enumerable-property-symbols-3.0.2.tgz#b5fde77f22cbe35f390b4e089922c50bce6ef664" + integrity sha512-I0UBV/XOz1XkIJHEUDMZAbzCThU/H8DxmSfmdGcKPnVhu2VfFqr34jr9777IyaTYvxjedWhqVIilEDsCdP5G6g== + +get-stream@^6.0.0, get-stream@^6.0.1: + version "6.0.1" + resolved "https://registry.yarnpkg.com/get-stream/-/get-stream-6.0.1.tgz#a262d8eef67aced57c2852ad6167526a43cbf7b7" + integrity sha512-ts6Wi+2j3jQjqi70w5AlN8DFnkSwC+MqmxEzdEALB2qXZYV3X/b1CTfgPLGJNMeAWxdPfU8FO1ms3NUfaHCPYg== + +github-slugger@^1.5.0: + version "1.5.0" + resolved "https://registry.yarnpkg.com/github-slugger/-/github-slugger-1.5.0.tgz#17891bbc73232051474d68bd867a34625c955f7d" + integrity sha512-wIh+gKBI9Nshz2o46B0B3f5k/W+WI9ZAv6y5Dn5WJ5SK1t0TnDimB4WE5rmTD05ZAIn8HALCZVmCsvj0w0v0lw== + +glob-parent@^5.1.2, glob-parent@~5.1.2: + version "5.1.2" + resolved "https://registry.yarnpkg.com/glob-parent/-/glob-parent-5.1.2.tgz#869832c58034fe68a4093c17dc15e8340d8401c4" + integrity sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow== + dependencies: + is-glob "^4.0.1" + +glob-parent@^6.0.1: + version "6.0.2" + resolved "https://registry.yarnpkg.com/glob-parent/-/glob-parent-6.0.2.tgz#6d237d99083950c79290f24c7642a3de9a28f9e3" + integrity sha512-XxwI8EOhVQgWp6iDL+3b0r86f4d6AX6zSU55HfB4ydCEuXLXc5FcYeOu+nnGftS4TEju/11rt4KJPTMgbfmv4A== + dependencies: + is-glob "^4.0.3" + +glob-to-regexp@^0.4.1: + version "0.4.1" + resolved "https://registry.yarnpkg.com/glob-to-regexp/-/glob-to-regexp-0.4.1.tgz#c75297087c851b9a578bd217dd59a92f59fe546e" + integrity sha512-lkX1HJXwyMcprw/5YUZc2s7DrpAiHB21/V+E1rHUrVNokkvB6bqMzT0VfV6/86ZNabt1k14YOIaT7nDvOX3Iiw== + +glob@^7.0.0, glob@^7.1.3, glob@^7.1.6: + version "7.2.3" + resolved "https://registry.yarnpkg.com/glob/-/glob-7.2.3.tgz#b8df0fb802bbfa8e89bd1d938b4e16578ed44f2b" + integrity sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q== + dependencies: + fs.realpath "^1.0.0" + inflight "^1.0.4" + inherits "2" + minimatch "^3.1.1" + once "^1.3.0" + path-is-absolute "^1.0.0" + +global-dirs@^3.0.0: + version "3.0.1" + resolved "https://registry.yarnpkg.com/global-dirs/-/global-dirs-3.0.1.tgz#0c488971f066baceda21447aecb1a8b911d22485" + integrity sha512-NBcGGFbBA9s1VzD41QXDG+3++t9Mn5t1FpLdhESY6oKY4gYTFpX4wO3sqGUa0Srjtbfj3szX0RnemmrVRUdULA== + dependencies: + ini "2.0.0" + +global-modules@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/global-modules/-/global-modules-2.0.0.tgz#997605ad2345f27f51539bea26574421215c7780" + integrity sha512-NGbfmJBp9x8IxyJSd1P+otYK8vonoJactOogrVfFRIAEY1ukil8RSKDz2Yo7wh1oihl51l/r6W4epkeKJHqL8A== + dependencies: + global-prefix "^3.0.0" + +global-prefix@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/global-prefix/-/global-prefix-3.0.0.tgz#fc85f73064df69f50421f47f883fe5b913ba9b97" + integrity sha512-awConJSVCHVGND6x3tmMaKcQvwXLhjdkmomy2W+Goaui8YPgYgXJZewhg3fWC+DlfqqQuWg8AwqjGTD2nAPVWg== + dependencies: + ini "^1.3.5" + kind-of "^6.0.2" + which "^1.3.1" + +globals@^11.1.0: + version "11.12.0" + resolved "https://registry.yarnpkg.com/globals/-/globals-11.12.0.tgz#ab8795338868a0babd8525758018c2a7eb95c42e" + integrity sha512-WOBp/EEGUiIsJSp7wcv/y6MO+lV9UoncWqxuFfm8eBwzWNgyfBd6Gz+IeKQ9jCmyhoH99g15M3T+QaVHFjizVA== + +globby@^11.0.1, globby@^11.0.4, globby@^11.1.0: + version "11.1.0" + resolved "https://registry.yarnpkg.com/globby/-/globby-11.1.0.tgz#bd4be98bb042f83d796f7e3811991fbe82a0d34b" + integrity sha512-jhIXaOzy1sb8IyocaruWSn1TjmnBVs8Ayhcy83rmxNJ8q2uWKCAj3CnJY+KpGSXCueAPc0i05kVvVKtP1t9S3g== + dependencies: + array-union "^2.1.0" + dir-glob "^3.0.1" + fast-glob "^3.2.9" + ignore "^5.2.0" + merge2 "^1.4.1" + slash "^3.0.0" + +globby@^13.1.1: + version "13.2.2" + resolved "https://registry.yarnpkg.com/globby/-/globby-13.2.2.tgz#63b90b1bf68619c2135475cbd4e71e66aa090592" + integrity sha512-Y1zNGV+pzQdh7H39l9zgB4PJqjRNqydvdYCDG4HFXM4XuvSaQQlEc91IU1yALL8gUTDomgBAfz3XJdmUS+oo0w== + dependencies: + dir-glob "^3.0.1" + fast-glob "^3.3.0" + ignore "^5.2.4" + merge2 "^1.4.1" + slash "^4.0.0" + +gopd@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/gopd/-/gopd-1.0.1.tgz#29ff76de69dac7489b7c0918a5788e56477c332c" + integrity sha512-d65bNlIadxvpb/A2abVdlqKqV563juRnZ1Wtk6s1sIR8uNsXR70xqIzVqxVf1eTqDunwT2MkczEeaezCKTZhwA== + dependencies: + get-intrinsic "^1.1.3" + +got@^12.1.0: + version "12.6.1" + resolved "https://registry.yarnpkg.com/got/-/got-12.6.1.tgz#8869560d1383353204b5a9435f782df9c091f549" + integrity sha512-mThBblvlAF1d4O5oqyvN+ZxLAYwIJK7bpMxgYqPD9okW0C3qm5FFn7k811QrcuEBwaogR3ngOFoCfs6mRv7teQ== + dependencies: + "@sindresorhus/is" "^5.2.0" + "@szmarczak/http-timer" "^5.0.1" + cacheable-lookup "^7.0.0" + cacheable-request "^10.2.8" + decompress-response "^6.0.0" + form-data-encoder "^2.1.2" + get-stream "^6.0.1" + http2-wrapper "^2.1.10" + lowercase-keys "^3.0.0" + p-cancelable "^3.0.0" + responselike "^3.0.0" + +graceful-fs@4.2.10: + version "4.2.10" + resolved "https://registry.yarnpkg.com/graceful-fs/-/graceful-fs-4.2.10.tgz#147d3a006da4ca3ce14728c7aefc287c367d7a6c" + integrity sha512-9ByhssR2fPVsNZj478qUUbKfmL0+t5BDVyjShtyZZLiK7ZDAArFFfopyOTj0M05wE2tJPisA4iTnnXl2YoPvOA== + +graceful-fs@^4.1.2, graceful-fs@^4.1.6, graceful-fs@^4.2.0, graceful-fs@^4.2.4, graceful-fs@^4.2.6, graceful-fs@^4.2.9: + version "4.2.11" + resolved "https://registry.yarnpkg.com/graceful-fs/-/graceful-fs-4.2.11.tgz#4183e4e8bf08bb6e05bbb2f7d2e0c8f712ca40e3" + integrity sha512-RbJ5/jmFcNNCcDV5o9eTnBLJ/HszWV0P73bc+Ff4nS/rJj+YaS6IGyiOL0VoBYX+l1Wrl3k63h/KrH+nhJ0XvQ== + +gray-matter@^4.0.3: + version "4.0.3" + resolved "https://registry.yarnpkg.com/gray-matter/-/gray-matter-4.0.3.tgz#e893c064825de73ea1f5f7d88c7a9f7274288798" + integrity sha512-5v6yZd4JK3eMI3FqqCouswVqwugaA9r4dNZB1wwcmrD02QkV5H0y7XBQW8QwQqEaZY1pM9aqORSORhJRdNK44Q== + dependencies: + js-yaml "^3.13.1" + kind-of "^6.0.2" + section-matter "^1.0.0" + strip-bom-string "^1.0.0" + +gzip-size@^6.0.0: + version "6.0.0" + resolved "https://registry.yarnpkg.com/gzip-size/-/gzip-size-6.0.0.tgz#065367fd50c239c0671cbcbad5be3e2eeb10e462" + integrity sha512-ax7ZYomf6jqPTQ4+XCpUGyXKHk5WweS+e05MBO4/y3WJ5RkmPXNKvX+bx1behVILVwr6JSQvZAku021CHPXG3Q== + dependencies: + duplexer "^0.1.2" + +handle-thing@^2.0.0: + version "2.0.1" + resolved "https://registry.yarnpkg.com/handle-thing/-/handle-thing-2.0.1.tgz#857f79ce359580c340d43081cc648970d0bb234e" + integrity sha512-9Qn4yBxelxoh2Ow62nP+Ka/kMnOXRi8BXnRaUwezLNhqelnN49xKz4F/dPP8OYLxLxq6JDtZb2i9XznUQbNPTg== + +handlebars@^4.7.7: + version "4.7.8" + resolved "https://registry.yarnpkg.com/handlebars/-/handlebars-4.7.8.tgz#41c42c18b1be2365439188c77c6afae71c0cd9e9" + integrity sha512-vafaFqs8MZkRrSX7sFVUdo3ap/eNiLnb4IakshzvP56X5Nr1iGKAIqdX6tMlm6HcNRIkr6AxO5jFEoJzzpT8aQ== + dependencies: + minimist "^1.2.5" + neo-async "^2.6.2" + source-map "^0.6.1" + wordwrap "^1.0.0" + optionalDependencies: + uglify-js "^3.1.4" + +has-flag@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/has-flag/-/has-flag-3.0.0.tgz#b5d454dc2199ae225699f3467e5a07f3b955bafd" + integrity sha512-sKJf1+ceQBr4SMkvQnBDNDtf4TXpVhVGateu0t918bl30FnbE2m4vNLX+VWe/dpjlb+HugGYzW7uQXH98HPEYw== + +has-flag@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/has-flag/-/has-flag-4.0.0.tgz#944771fd9c81c81265c4d6941860da06bb59479b" + integrity sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ== + +has-property-descriptors@^1.0.0: + version "1.0.1" + resolved "https://registry.yarnpkg.com/has-property-descriptors/-/has-property-descriptors-1.0.1.tgz#52ba30b6c5ec87fd89fa574bc1c39125c6f65340" + integrity sha512-VsX8eaIewvas0xnvinAe9bw4WfIeODpGYikiWYLH+dma0Jw6KHYqWiWfhQlgOVK8D6PvjubK5Uc4P0iIhIcNVg== + dependencies: + get-intrinsic "^1.2.2" + +has-proto@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/has-proto/-/has-proto-1.0.1.tgz#1885c1305538958aff469fef37937c22795408e0" + integrity sha512-7qE+iP+O+bgF9clE5+UoBFzE65mlBiVj3tKCrlNQ0Ogwm0BjpT/gK4SlLYDMybDh5I3TCTKnPPa0oMG7JDYrhg== + +has-symbols@^1.0.3: + version "1.0.3" + resolved "https://registry.yarnpkg.com/has-symbols/-/has-symbols-1.0.3.tgz#bb7b2c4349251dce87b125f7bdf874aa7c8b39f8" + integrity sha512-l3LCuF6MgDNwTDKkdYGEihYjt5pRPbEg46rtlmnSPlUbgmB8LOIrKJbYYFBSbnPaJexMKtiPO8hmeRjRz2Td+A== + +has-yarn@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/has-yarn/-/has-yarn-3.0.0.tgz#c3c21e559730d1d3b57e28af1f30d06fac38147d" + integrity sha512-IrsVwUHhEULx3R8f/aA8AHuEzAorplsab/v8HBzEiIukwq5i/EC+xmOW+HfP1OaDP+2JkgT1yILHN2O3UFIbcA== + +hasown@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/hasown/-/hasown-2.0.0.tgz#f4c513d454a57b7c7e1650778de226b11700546c" + integrity sha512-vUptKVTpIJhcczKBbgnS+RtcuYMB8+oNzPK2/Hp3hanz8JmpATdmmgLgSaadVREkDm+e2giHwY3ZRkyjSIDDFA== + dependencies: + function-bind "^1.1.2" + +hast-util-from-parse5@^8.0.0: + version "8.0.1" + resolved "https://registry.yarnpkg.com/hast-util-from-parse5/-/hast-util-from-parse5-8.0.1.tgz#654a5676a41211e14ee80d1b1758c399a0327651" + integrity sha512-Er/Iixbc7IEa7r/XLtuG52zoqn/b3Xng/w6aZQ0xGVxzhw5xUFxcRqdPzP6yFi/4HBYRaifaI5fQ1RH8n0ZeOQ== + dependencies: + "@types/hast" "^3.0.0" + "@types/unist" "^3.0.0" + devlop "^1.0.0" + hastscript "^8.0.0" + property-information "^6.0.0" + vfile "^6.0.0" + vfile-location "^5.0.0" + web-namespaces "^2.0.0" + +hast-util-parse-selector@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/hast-util-parse-selector/-/hast-util-parse-selector-4.0.0.tgz#352879fa86e25616036037dd8931fb5f34cb4a27" + integrity sha512-wkQCkSYoOGCRKERFWcxMVMOcYE2K1AaNLU8DXS9arxnLOUEWbOXKXiJUNzEpqZ3JOKpnha3jkFrumEjVliDe7A== + dependencies: + "@types/hast" "^3.0.0" + +hast-util-raw@^9.0.0: + version "9.0.1" + resolved "https://registry.yarnpkg.com/hast-util-raw/-/hast-util-raw-9.0.1.tgz#2ba8510e4ed2a1e541cde2a4ebb5c38ab4c82c2d" + integrity sha512-5m1gmba658Q+lO5uqL5YNGQWeh1MYWZbZmWrM5lncdcuiXuo5E2HT/CIOp0rLF8ksfSwiCVJ3twlgVRyTGThGA== + dependencies: + "@types/hast" "^3.0.0" + "@types/unist" "^3.0.0" + "@ungap/structured-clone" "^1.0.0" + hast-util-from-parse5 "^8.0.0" + hast-util-to-parse5 "^8.0.0" + html-void-elements "^3.0.0" + mdast-util-to-hast "^13.0.0" + parse5 "^7.0.0" + unist-util-position "^5.0.0" + unist-util-visit "^5.0.0" + vfile "^6.0.0" + web-namespaces "^2.0.0" + zwitch "^2.0.0" + +hast-util-to-estree@^3.0.0: + version "3.1.0" + resolved "https://registry.yarnpkg.com/hast-util-to-estree/-/hast-util-to-estree-3.1.0.tgz#f2afe5e869ddf0cf690c75f9fc699f3180b51b19" + integrity sha512-lfX5g6hqVh9kjS/B9E2gSkvHH4SZNiQFiqWS0x9fENzEl+8W12RqdRxX6d/Cwxi30tPQs3bIO+aolQJNp1bIyw== + dependencies: + "@types/estree" "^1.0.0" + "@types/estree-jsx" "^1.0.0" + "@types/hast" "^3.0.0" + comma-separated-tokens "^2.0.0" + devlop "^1.0.0" + estree-util-attach-comments "^3.0.0" + estree-util-is-identifier-name "^3.0.0" + hast-util-whitespace "^3.0.0" + mdast-util-mdx-expression "^2.0.0" + mdast-util-mdx-jsx "^3.0.0" + mdast-util-mdxjs-esm "^2.0.0" + property-information "^6.0.0" + space-separated-tokens "^2.0.0" + style-to-object "^0.4.0" + unist-util-position "^5.0.0" + zwitch "^2.0.0" + +hast-util-to-jsx-runtime@^2.0.0: + version "2.2.0" + resolved "https://registry.yarnpkg.com/hast-util-to-jsx-runtime/-/hast-util-to-jsx-runtime-2.2.0.tgz#ffd59bfcf0eb8321c6ed511bfc4b399ac3404bc2" + integrity sha512-wSlp23N45CMjDg/BPW8zvhEi3R+8eRE1qFbjEyAUzMCzu2l1Wzwakq+Tlia9nkCtEl5mDxa7nKHsvYJ6Gfn21A== + dependencies: + "@types/hast" "^3.0.0" + "@types/unist" "^3.0.0" + comma-separated-tokens "^2.0.0" + hast-util-whitespace "^3.0.0" + property-information "^6.0.0" + space-separated-tokens "^2.0.0" + style-to-object "^0.4.0" + unist-util-position "^5.0.0" + vfile-message "^4.0.0" + +hast-util-to-parse5@^8.0.0: + version "8.0.0" + resolved "https://registry.yarnpkg.com/hast-util-to-parse5/-/hast-util-to-parse5-8.0.0.tgz#477cd42d278d4f036bc2ea58586130f6f39ee6ed" + integrity sha512-3KKrV5ZVI8if87DVSi1vDeByYrkGzg4mEfeu4alwgmmIeARiBLKCZS2uw5Gb6nU9x9Yufyj3iudm6i7nl52PFw== + dependencies: + "@types/hast" "^3.0.0" + comma-separated-tokens "^2.0.0" + devlop "^1.0.0" + property-information "^6.0.0" + space-separated-tokens "^2.0.0" + web-namespaces "^2.0.0" + zwitch "^2.0.0" + +hast-util-whitespace@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/hast-util-whitespace/-/hast-util-whitespace-3.0.0.tgz#7778ed9d3c92dd9e8c5c8f648a49c21fc51cb621" + integrity sha512-88JUN06ipLwsnv+dVn+OIYOvAuvBMy/Qoi6O7mQHxdPXpjy+Cd6xRkWwux7DKO+4sYILtLBRIKgsdpS2gQc7qw== + dependencies: + "@types/hast" "^3.0.0" + +hastscript@^8.0.0: + version "8.0.0" + resolved "https://registry.yarnpkg.com/hastscript/-/hastscript-8.0.0.tgz#4ef795ec8dee867101b9f23cc830d4baf4fd781a" + integrity sha512-dMOtzCEd3ABUeSIISmrETiKuyydk1w0pa+gE/uormcTpSYuaNJPbX1NU3JLyscSLjwAQM8bWMhhIlnCqnRvDTw== + dependencies: + "@types/hast" "^3.0.0" + comma-separated-tokens "^2.0.0" + hast-util-parse-selector "^4.0.0" + property-information "^6.0.0" + space-separated-tokens "^2.0.0" + +he@^1.2.0: + version "1.2.0" + resolved "https://registry.yarnpkg.com/he/-/he-1.2.0.tgz#84ae65fa7eafb165fddb61566ae14baf05664f0f" + integrity sha512-F/1DnUGPopORZi0ni+CvrCgHQ5FyEAHRLSApuYWMmrbSwoN2Mn/7k+Gl38gJnR7yyDZk6WLXwiGod1JOWNDKGw== + +history@^4.9.0: + version "4.10.1" + resolved "https://registry.yarnpkg.com/history/-/history-4.10.1.tgz#33371a65e3a83b267434e2b3f3b1b4c58aad4cf3" + integrity sha512-36nwAD620w12kuzPAsyINPWJqlNbij+hpK1k9XRloDtym8mxzGYl2c17LnV6IAGB2Dmg4tEa7G7DlawS0+qjew== + dependencies: + "@babel/runtime" "^7.1.2" + loose-envify "^1.2.0" + resolve-pathname "^3.0.0" + tiny-invariant "^1.0.2" + tiny-warning "^1.0.0" + value-equal "^1.0.1" + +hoist-non-react-statics@^3.1.0: + version "3.3.2" + resolved "https://registry.yarnpkg.com/hoist-non-react-statics/-/hoist-non-react-statics-3.3.2.tgz#ece0acaf71d62c2969c2ec59feff42a4b1a85b45" + integrity sha512-/gGivxi8JPKWNm/W0jSmzcMPpfpPLc3dY/6GxhX2hQ9iGj3aDfklV4ET7NjKpSinLpJ5vafa9iiGIEZg10SfBw== + dependencies: + react-is "^16.7.0" + +hpack.js@^2.1.6: + version "2.1.6" + resolved "https://registry.yarnpkg.com/hpack.js/-/hpack.js-2.1.6.tgz#87774c0949e513f42e84575b3c45681fade2a0b2" + integrity sha512-zJxVehUdMGIKsRaNt7apO2Gqp0BdqW5yaiGHXXmbpvxgBYVZnAql+BJb4RO5ad2MgpbZKn5G6nMnegrH1FcNYQ== + dependencies: + inherits "^2.0.1" + obuf "^1.0.0" + readable-stream "^2.0.1" + wbuf "^1.1.0" + +html-entities@^2.3.2: + version "2.4.0" + resolved "https://registry.yarnpkg.com/html-entities/-/html-entities-2.4.0.tgz#edd0cee70402584c8c76cc2c0556db09d1f45061" + integrity sha512-igBTJcNNNhvZFRtm8uA6xMY6xYleeDwn3PeBCkDz7tHttv4F2hsDI2aPgNERWzvRcNYHNT3ymRaQzllmXj4YsQ== + +html-escaper@^2.0.2: + version "2.0.2" + resolved "https://registry.yarnpkg.com/html-escaper/-/html-escaper-2.0.2.tgz#dfd60027da36a36dfcbe236262c00a5822681453" + integrity sha512-H2iMtd0I4Mt5eYiapRdIDjp+XzelXQ0tFE4JS7YFwFevXXMmOp9myNrUvCg0D6ws8iqkRPBfKHgbwig1SmlLfg== + +html-minifier-terser@^6.0.2: + version "6.1.0" + resolved "https://registry.yarnpkg.com/html-minifier-terser/-/html-minifier-terser-6.1.0.tgz#bfc818934cc07918f6b3669f5774ecdfd48f32ab" + integrity sha512-YXxSlJBZTP7RS3tWnQw74ooKa6L9b9i9QYXY21eUEvhZ3u9XLfv6OnFsQq6RxkhHygsaUMvYsZRV5rU/OVNZxw== + dependencies: + camel-case "^4.1.2" + clean-css "^5.2.2" + commander "^8.3.0" + he "^1.2.0" + param-case "^3.0.4" + relateurl "^0.2.7" + terser "^5.10.0" + +html-minifier-terser@^7.2.0: + version "7.2.0" + resolved "https://registry.yarnpkg.com/html-minifier-terser/-/html-minifier-terser-7.2.0.tgz#18752e23a2f0ed4b0f550f217bb41693e975b942" + integrity sha512-tXgn3QfqPIpGl9o+K5tpcj3/MN4SfLtsx2GWwBC3SSd0tXQGyF3gsSqad8loJgKZGM3ZxbYDd5yhiBIdWpmvLA== + dependencies: + camel-case "^4.1.2" + clean-css "~5.3.2" + commander "^10.0.0" + entities "^4.4.0" + param-case "^3.0.4" + relateurl "^0.2.7" + terser "^5.15.1" + +html-tags@^3.3.1: + version "3.3.1" + resolved "https://registry.yarnpkg.com/html-tags/-/html-tags-3.3.1.tgz#a04026a18c882e4bba8a01a3d39cfe465d40b5ce" + integrity sha512-ztqyC3kLto0e9WbNp0aeP+M3kTt+nbaIveGmUxAtZa+8iFgKLUOD4YKM5j+f3QD89bra7UeumolZHKuOXnTmeQ== + +html-void-elements@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/html-void-elements/-/html-void-elements-3.0.0.tgz#fc9dbd84af9e747249034d4d62602def6517f1d7" + integrity sha512-bEqo66MRXsUGxWHV5IP0PUiAWwoEjba4VCzg0LjFJBpchPaTfyfCKTG6bc5F8ucKec3q5y6qOdGyYTSBEvhCrg== + +html-webpack-plugin@^5.5.3: + version "5.5.3" + resolved "https://registry.yarnpkg.com/html-webpack-plugin/-/html-webpack-plugin-5.5.3.tgz#72270f4a78e222b5825b296e5e3e1328ad525a3e" + integrity sha512-6YrDKTuqaP/TquFH7h4srYWsZx+x6k6+FbsTm0ziCwGHDP78Unr1r9F/H4+sGmMbX08GQcJ+K64x55b+7VM/jg== + dependencies: + "@types/html-minifier-terser" "^6.0.0" + html-minifier-terser "^6.0.2" + lodash "^4.17.21" + pretty-error "^4.0.0" + tapable "^2.0.0" + +htmlparser2@^6.1.0: + version "6.1.0" + resolved "https://registry.yarnpkg.com/htmlparser2/-/htmlparser2-6.1.0.tgz#c4d762b6c3371a05dbe65e94ae43a9f845fb8fb7" + integrity sha512-gyyPk6rgonLFEDGoeRgQNaEUvdJ4ktTmmUh/h2t7s+M8oPpIPxgNACWa+6ESR57kXstwqPiCut0V8NRpcwgU7A== + dependencies: + domelementtype "^2.0.1" + domhandler "^4.0.0" + domutils "^2.5.2" + entities "^2.0.0" + +htmlparser2@^8.0.1: + version "8.0.2" + resolved "https://registry.yarnpkg.com/htmlparser2/-/htmlparser2-8.0.2.tgz#f002151705b383e62433b5cf466f5b716edaec21" + integrity sha512-GYdjWKDkbRLkZ5geuHs5NY1puJ+PXwP7+fHPRz06Eirsb9ugf6d8kkXav6ADhcODhFFPMIXyxkxSuMf3D6NCFA== + dependencies: + domelementtype "^2.3.0" + domhandler "^5.0.3" + domutils "^3.0.1" + entities "^4.4.0" + +http-cache-semantics@^4.1.1: + version "4.1.1" + resolved "https://registry.yarnpkg.com/http-cache-semantics/-/http-cache-semantics-4.1.1.tgz#abe02fcb2985460bf0323be664436ec3476a6d5a" + integrity sha512-er295DKPVsV82j5kw1Gjt+ADA/XYHsajl82cGNQG2eyoPkvgUhX+nDIyelzhIWbbsXP39EHcI6l5tYs2FYqYXQ== + +http-deceiver@^1.2.7: + version "1.2.7" + resolved "https://registry.yarnpkg.com/http-deceiver/-/http-deceiver-1.2.7.tgz#fa7168944ab9a519d337cb0bec7284dc3e723d87" + integrity sha512-LmpOGxTfbpgtGVxJrj5k7asXHCgNZp5nLfp+hWc8QQRqtb7fUy6kRY3BO1h9ddF6yIPYUARgxGOwB42DnxIaNw== + +http-errors@2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/http-errors/-/http-errors-2.0.0.tgz#b7774a1486ef73cf7667ac9ae0858c012c57b9d3" + integrity sha512-FtwrG/euBzaEjYeRqOgly7G0qviiXoJWnvEH2Z1plBdXgbyjv34pHTSb9zoeHMyDy33+DWy5Wt9Wo+TURtOYSQ== + dependencies: + depd "2.0.0" + inherits "2.0.4" + setprototypeof "1.2.0" + statuses "2.0.1" + toidentifier "1.0.1" + +http-errors@~1.6.2: + version "1.6.3" + resolved "https://registry.yarnpkg.com/http-errors/-/http-errors-1.6.3.tgz#8b55680bb4be283a0b5bf4ea2e38580be1d9320d" + integrity sha512-lks+lVC8dgGyh97jxvxeYTWQFvh4uw4yC12gVl63Cg30sjPX4wuGcdkICVXDAESr6OJGjqGA8Iz5mkeN6zlD7A== + dependencies: + depd "~1.1.2" + inherits "2.0.3" + setprototypeof "1.1.0" + statuses ">= 1.4.0 < 2" + +http-parser-js@>=0.5.1: + version "0.5.8" + resolved "https://registry.yarnpkg.com/http-parser-js/-/http-parser-js-0.5.8.tgz#af23090d9ac4e24573de6f6aecc9d84a48bf20e3" + integrity sha512-SGeBX54F94Wgu5RH3X5jsDtf4eHyRogWX1XGT3b4HuW3tQPM4AaBzoUji/4AAJNXCEOWZ5O0DgZmJw1947gD5Q== + +http-proxy-middleware@^2.0.3: + version "2.0.6" + resolved "https://registry.yarnpkg.com/http-proxy-middleware/-/http-proxy-middleware-2.0.6.tgz#e1a4dd6979572c7ab5a4e4b55095d1f32a74963f" + integrity sha512-ya/UeJ6HVBYxrgYotAZo1KvPWlgB48kUJLDePFeneHsVujFaW5WNj2NgWCAE//B1Dl02BIfYlpNgBy8Kf8Rjmw== + dependencies: + "@types/http-proxy" "^1.17.8" + http-proxy "^1.18.1" + is-glob "^4.0.1" + is-plain-obj "^3.0.0" + micromatch "^4.0.2" + +http-proxy@^1.18.1: + version "1.18.1" + resolved "https://registry.yarnpkg.com/http-proxy/-/http-proxy-1.18.1.tgz#401541f0534884bbf95260334e72f88ee3976549" + integrity sha512-7mz/721AbnJwIVbnaSv1Cz3Am0ZLT/UBwkC92VlxhXv/k/BBQfM2fXElQNC27BVGr0uwUpplYPQM9LnaBMR5NQ== + dependencies: + eventemitter3 "^4.0.0" + follow-redirects "^1.0.0" + requires-port "^1.0.0" + +http2-wrapper@^2.1.10: + version "2.2.1" + resolved "https://registry.yarnpkg.com/http2-wrapper/-/http2-wrapper-2.2.1.tgz#310968153dcdedb160d8b72114363ef5fce1f64a" + integrity sha512-V5nVw1PAOgfI3Lmeaj2Exmeg7fenjhRUgz1lPSezy1CuhPYbgQtbQj4jZfEAEMlaL+vupsvhjqCyjzob0yxsmQ== + dependencies: + quick-lru "^5.1.1" + resolve-alpn "^1.2.0" + +human-signals@^2.1.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/human-signals/-/human-signals-2.1.0.tgz#dc91fcba42e4d06e4abaed33b3e7a3c02f514ea0" + integrity sha512-B4FFZ6q/T2jhhksgkbEW3HBvWIfDW85snkQgawt07S7J5QXTk6BkNV+0yAeZrM5QpMAdYlocGoljn0sJ/WQkFw== + +iconv-lite@0.4.24: + version "0.4.24" + resolved "https://registry.yarnpkg.com/iconv-lite/-/iconv-lite-0.4.24.tgz#2022b4b25fbddc21d2f524974a474aafe733908b" + integrity sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA== + dependencies: + safer-buffer ">= 2.1.2 < 3" + +icss-utils@^5.0.0, icss-utils@^5.1.0: + version "5.1.0" + resolved "https://registry.yarnpkg.com/icss-utils/-/icss-utils-5.1.0.tgz#c6be6858abd013d768e98366ae47e25d5887b1ae" + integrity sha512-soFhflCVWLfRNOPU3iv5Z9VUdT44xFRbzjLsEzSr5AQmgqPMTHdU3PMT1Cf1ssx8fLNJDA1juftYl+PUcv3MqA== + +ignore@^5.2.0, ignore@^5.2.4: + version "5.3.0" + resolved "https://registry.yarnpkg.com/ignore/-/ignore-5.3.0.tgz#67418ae40d34d6999c95ff56016759c718c82f78" + integrity sha512-g7dmpshy+gD7mh88OC9NwSGTKoc3kyLAZQRU1mt53Aw/vnvfXnbC+F/7F7QoYVKbV+KNvJx8wArewKy1vXMtlg== + +image-size@^1.0.2: + version "1.0.2" + resolved "https://registry.yarnpkg.com/image-size/-/image-size-1.0.2.tgz#d778b6d0ab75b2737c1556dd631652eb963bc486" + integrity sha512-xfOoWjceHntRb3qFCrh5ZFORYH8XCdYpASltMhZ/Q0KZiOwjdE/Yl2QCiWdwD+lygV5bMCvauzgu5PxBX/Yerg== + dependencies: + queue "6.0.2" + +immer@^9.0.7: + version "9.0.21" + resolved "https://registry.yarnpkg.com/immer/-/immer-9.0.21.tgz#1e025ea31a40f24fb064f1fef23e931496330176" + integrity sha512-bc4NBHqOqSfRW7POMkHd51LvClaeMXpm8dx0e8oE2GORbq5aRK7Bxl4FyzVLdGtLmvLKL7BTDBG5ACQm4HWjTA== + +import-fresh@^3.1.0, import-fresh@^3.2.1, import-fresh@^3.3.0: + version "3.3.0" + resolved "https://registry.yarnpkg.com/import-fresh/-/import-fresh-3.3.0.tgz#37162c25fcb9ebaa2e6e53d5b4d88ce17d9e0c2b" + integrity sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw== + dependencies: + parent-module "^1.0.0" + resolve-from "^4.0.0" + +import-lazy@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/import-lazy/-/import-lazy-4.0.0.tgz#e8eb627483a0a43da3c03f3e35548be5cb0cc153" + integrity sha512-rKtvo6a868b5Hu3heneU+L4yEQ4jYKLtjpnPeUdK7h0yzXGmyBTypknlkCvHFBqfX9YlorEiMM6Dnq/5atfHkw== + +imurmurhash@^0.1.4: + version "0.1.4" + resolved "https://registry.yarnpkg.com/imurmurhash/-/imurmurhash-0.1.4.tgz#9218b9b2b928a238b13dc4fb6b6d576f231453ea" + integrity sha512-JmXMZ6wuvDmLiHEml9ykzqO6lwFbof0GG4IkcGaENdCRDDmMVnny7s5HsIgHCbaq0w2MyPhDqkhTUgS2LU2PHA== + +indent-string@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/indent-string/-/indent-string-4.0.0.tgz#624f8f4497d619b2d9768531d58f4122854d7251" + integrity sha512-EdDDZu4A2OyIK7Lr/2zG+w5jmbuk1DVBnEwREQvBzspBJkCEbRa8GxU1lghYcaGJCnRWibjDXlq779X1/y5xwg== + +infima@0.2.0-alpha.43: + version "0.2.0-alpha.43" + resolved "https://registry.yarnpkg.com/infima/-/infima-0.2.0-alpha.43.tgz#f7aa1d7b30b6c08afef441c726bac6150228cbe0" + integrity sha512-2uw57LvUqW0rK/SWYnd/2rRfxNA5DDNOh33jxF7fy46VWoNhGxiUQyVZHbBMjQ33mQem0cjdDVwgWVAmlRfgyQ== + +inflight@^1.0.4: + version "1.0.6" + resolved "https://registry.yarnpkg.com/inflight/-/inflight-1.0.6.tgz#49bd6331d7d02d0c09bc910a1075ba8165b56df9" + integrity sha512-k92I/b08q4wvFscXCLvqfsHCrjrF7yiXsQuIVvVE7N82W3+aqpzuUdBbfhWcy/FZR3/4IgflMgKLOsvPDrGCJA== + dependencies: + once "^1.3.0" + wrappy "1" + +inherits@2, inherits@2.0.4, inherits@^2.0.1, inherits@^2.0.3, inherits@~2.0.3: + version "2.0.4" + resolved "https://registry.yarnpkg.com/inherits/-/inherits-2.0.4.tgz#0fa2c64f932917c3433a0ded55363aae37416b7c" + integrity sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ== + +inherits@2.0.3: + version "2.0.3" + resolved "https://registry.yarnpkg.com/inherits/-/inherits-2.0.3.tgz#633c2c83e3da42a502f52466022480f4208261de" + integrity sha512-x00IRNXNy63jwGkJmzPigoySHbaqpNuzKbBOmzK+g2OdZpQ9w+sxCN+VSB3ja7IAge2OP2qpfxTjeNcyjmW1uw== + +ini@2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/ini/-/ini-2.0.0.tgz#e5fd556ecdd5726be978fa1001862eacb0a94bc5" + integrity sha512-7PnF4oN3CvZF23ADhA5wRaYEQpJ8qygSkbtTXWBeXWXmEVRXK+1ITciHWwHhsjv1TmW0MgacIv6hEi5pX5NQdA== + +ini@^1.3.4, ini@^1.3.5, ini@~1.3.0: + version "1.3.8" + resolved "https://registry.yarnpkg.com/ini/-/ini-1.3.8.tgz#a29da425b48806f34767a4efce397269af28432c" + integrity sha512-JV/yugV2uzW5iMRSiZAyDtQd+nxtUnjeLt0acNdw98kKLrvuRVyB80tsREOE7yvGVgalhZ6RNXCmEHkUKBKxew== + +inline-style-parser@0.1.1: + version "0.1.1" + resolved "https://registry.yarnpkg.com/inline-style-parser/-/inline-style-parser-0.1.1.tgz#ec8a3b429274e9c0a1f1c4ffa9453a7fef72cea1" + integrity sha512-7NXolsK4CAS5+xvdj5OMMbI962hU/wvwoxk+LWR9Ek9bVtyuuYScDN6eS0rUm6TxApFpw7CX1o4uJzcd4AyD3Q== + +interpret@^1.0.0: + version "1.4.0" + resolved "https://registry.yarnpkg.com/interpret/-/interpret-1.4.0.tgz#665ab8bc4da27a774a40584e812e3e0fa45b1a1e" + integrity sha512-agE4QfB2Lkp9uICn7BAqoscw4SZP9kTE2hxiFI3jBPmXJfdqiahTbUuKGsMoN2GtqL9AxhYioAcVvgsb1HvRbA== + +invariant@^2.2.4: + version "2.2.4" + resolved "https://registry.yarnpkg.com/invariant/-/invariant-2.2.4.tgz#610f3c92c9359ce1db616e538008d23ff35158e6" + integrity sha512-phJfQVBuaJM5raOpJjSfkiD6BpbCE4Ns//LaXl6wGYtUBY83nWS6Rf9tXm2e8VaK60JEjYldbPif/A2B1C2gNA== + dependencies: + loose-envify "^1.0.0" + +ipaddr.js@1.9.1: + version "1.9.1" + resolved "https://registry.yarnpkg.com/ipaddr.js/-/ipaddr.js-1.9.1.tgz#bff38543eeb8984825079ff3a2a8e6cbd46781b3" + integrity sha512-0KI/607xoxSToH7GjN1FfSbLoU0+btTicjsQSWQlh/hZykN8KpmMf7uYwPW3R+akZ6R/w18ZlXSHBYXiYUPO3g== + +ipaddr.js@^2.0.1: + version "2.1.0" + resolved "https://registry.yarnpkg.com/ipaddr.js/-/ipaddr.js-2.1.0.tgz#2119bc447ff8c257753b196fc5f1ce08a4cdf39f" + integrity sha512-LlbxQ7xKzfBusov6UMi4MFpEg0m+mAm9xyNGEduwXMEDuf4WfzB/RZwMVYEd7IKGvh4IUkEXYxtAVu9T3OelJQ== + +is-alphabetical@^2.0.0: + version "2.0.1" + resolved "https://registry.yarnpkg.com/is-alphabetical/-/is-alphabetical-2.0.1.tgz#01072053ea7c1036df3c7d19a6daaec7f19e789b" + integrity sha512-FWyyY60MeTNyeSRpkM2Iry0G9hpr7/9kD40mD/cGQEuilcZYS4okz8SN2Q6rLCJ8gbCt6fN+rC+6tMGS99LaxQ== + +is-alphanumerical@^2.0.0: + version "2.0.1" + resolved "https://registry.yarnpkg.com/is-alphanumerical/-/is-alphanumerical-2.0.1.tgz#7c03fbe96e3e931113e57f964b0a368cc2dfd875" + integrity sha512-hmbYhX/9MUMF5uh7tOXyK/n0ZvWpad5caBA17GsC6vyuCqaWliRG5K1qS9inmUhEMaOBIW7/whAnSwveW/LtZw== + dependencies: + is-alphabetical "^2.0.0" + is-decimal "^2.0.0" + +is-arrayish@^0.2.1: + version "0.2.1" + resolved "https://registry.yarnpkg.com/is-arrayish/-/is-arrayish-0.2.1.tgz#77c99840527aa8ecb1a8ba697b80645a7a926a9d" + integrity sha512-zz06S8t0ozoDXMG+ube26zeCTNXcKIPJZJi8hBrF4idCLms4CG9QtK7qBl1boi5ODzFpjswb5JPmHCbMpjaYzg== + +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" + integrity sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw== + dependencies: + binary-extensions "^2.0.0" + +is-ci@^3.0.1: + version "3.0.1" + resolved "https://registry.yarnpkg.com/is-ci/-/is-ci-3.0.1.tgz#db6ecbed1bd659c43dac0f45661e7674103d1867" + integrity sha512-ZYvCgrefwqoQ6yTyYUbQu64HsITZ3NfKX1lzaEYdkTDcfKzzCI/wthRRYKkdjHKFVgNiXKAKm65Zo1pk2as/QQ== + dependencies: + ci-info "^3.2.0" + +is-core-module@^2.13.0: + version "2.13.1" + resolved "https://registry.yarnpkg.com/is-core-module/-/is-core-module-2.13.1.tgz#ad0d7532c6fea9da1ebdc82742d74525c6273384" + integrity sha512-hHrIjvZsftOsvKSn2TRYl63zvxsgE0K+0mYMoH6gD4omR5IWB2KynivBQczo3+wF1cCkjzvptnI9Q0sPU66ilw== + dependencies: + hasown "^2.0.0" + +is-decimal@^2.0.0: + version "2.0.1" + resolved "https://registry.yarnpkg.com/is-decimal/-/is-decimal-2.0.1.tgz#9469d2dc190d0214fd87d78b78caecc0cc14eef7" + integrity sha512-AAB9hiomQs5DXWcRB1rqsxGUstbRroFOPPVAomNk/3XHR5JyEZChOyTWe2oayKnsSsr/kcGqF+z6yuH6HHpN0A== + +is-docker@^2.0.0, is-docker@^2.1.1: + version "2.2.1" + resolved "https://registry.yarnpkg.com/is-docker/-/is-docker-2.2.1.tgz#33eeabe23cfe86f14bde4408a02c0cfb853acdaa" + integrity sha512-F+i2BKsFrH66iaUFc0woD8sLy8getkwTwtOBjvs56Cx4CgJDeKQeqfz8wAYiSb8JOprWhHH5p77PbmYCvvUuXQ== + +is-extendable@^0.1.0: + version "0.1.1" + resolved "https://registry.yarnpkg.com/is-extendable/-/is-extendable-0.1.1.tgz#62b110e289a471418e3ec36a617d472e301dfc89" + integrity sha512-5BMULNob1vgFX6EjQw5izWDxrecWK9AM72rugNr0TFldMOi0fj6Jk+zeKIt0xGj4cEfQIJth4w3OKWOJ4f+AFw== + +is-extglob@^2.1.1: + version "2.1.1" + resolved "https://registry.yarnpkg.com/is-extglob/-/is-extglob-2.1.1.tgz#a88c02535791f02ed37c76a1b9ea9773c833f8c2" + integrity sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ== + +is-fullwidth-code-point@^3.0.0: + version "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-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" + integrity sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg== + dependencies: + is-extglob "^2.1.1" + +is-hexadecimal@^2.0.0: + version "2.0.1" + resolved "https://registry.yarnpkg.com/is-hexadecimal/-/is-hexadecimal-2.0.1.tgz#86b5bf668fca307498d319dfc03289d781a90027" + integrity sha512-DgZQp241c8oO6cA1SbTEWiXeoxV42vlcJxgH+B3hi1AiqqKruZR3ZGF8In3fj4+/y/7rHvlOZLZtgJ/4ttYGZg== + +is-installed-globally@^0.4.0: + version "0.4.0" + resolved "https://registry.yarnpkg.com/is-installed-globally/-/is-installed-globally-0.4.0.tgz#9a0fd407949c30f86eb6959ef1b7994ed0b7b520" + integrity sha512-iwGqO3J21aaSkC7jWnHP/difazwS7SFeIqxv6wEtLU8Y5KlzFTjyqcSIT0d8s4+dDhKytsk9PJZ2BkS5eZwQRQ== + dependencies: + global-dirs "^3.0.0" + is-path-inside "^3.0.2" + +is-npm@^6.0.0: + version "6.0.0" + resolved "https://registry.yarnpkg.com/is-npm/-/is-npm-6.0.0.tgz#b59e75e8915543ca5d881ecff864077cba095261" + integrity sha512-JEjxbSmtPSt1c8XTkVrlujcXdKV1/tvuQ7GwKcAlyiVLeYFQ2VHat8xfrDJsIkhCdF/tZ7CiIR3sy141c6+gPQ== + +is-number@^7.0.0: + version "7.0.0" + resolved "https://registry.yarnpkg.com/is-number/-/is-number-7.0.0.tgz#7535345b896734d5f80c4d06c50955527a14f12b" + integrity sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng== + +is-obj@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/is-obj/-/is-obj-1.0.1.tgz#3e4729ac1f5fde025cd7d83a896dab9f4f67db0f" + integrity sha512-l4RyHgRqGN4Y3+9JHVrNqO+tN0rV5My76uW5/nuO4K1b6vw5G8d/cmFjP9tRfEsdhZNt0IFdZuK/c2Vr4Nb+Qg== + +is-obj@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/is-obj/-/is-obj-2.0.0.tgz#473fb05d973705e3fd9620545018ca8e22ef4982" + integrity sha512-drqDG3cbczxxEJRoOXcOjtdp1J/lyp1mNn0xaznRs8+muBhgQcrnbspox5X5fOw0HnMnbfDzvnEMEtqDEJEo8w== + +is-path-cwd@^2.2.0: + version "2.2.0" + resolved "https://registry.yarnpkg.com/is-path-cwd/-/is-path-cwd-2.2.0.tgz#67d43b82664a7b5191fd9119127eb300048a9fdb" + integrity sha512-w942bTcih8fdJPJmQHFzkS76NEP8Kzzvmw92cXsazb8intwLqPibPPdXf4ANdKV3rYMuuQYGIWtvz9JilB3NFQ== + +is-path-inside@^3.0.2: + version "3.0.3" + resolved "https://registry.yarnpkg.com/is-path-inside/-/is-path-inside-3.0.3.tgz#d231362e53a07ff2b0e0ea7fed049161ffd16283" + integrity sha512-Fd4gABb+ycGAmKou8eMftCupSir5lRxqf4aD/vd0cD2qc4HL07OjCeuHMr8Ro4CoMaeCKDB0/ECBOVWjTwUvPQ== + +is-plain-obj@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/is-plain-obj/-/is-plain-obj-3.0.0.tgz#af6f2ea14ac5a646183a5bbdb5baabbc156ad9d7" + integrity sha512-gwsOE28k+23GP1B6vFl1oVh/WOzmawBrKwo5Ev6wMKzPkaXaCDIQKzLnvsA42DRlbVTWorkgTKIviAKCWkfUwA== + +is-plain-obj@^4.0.0: + version "4.1.0" + resolved "https://registry.yarnpkg.com/is-plain-obj/-/is-plain-obj-4.1.0.tgz#d65025edec3657ce032fd7db63c97883eaed71f0" + integrity sha512-+Pgi+vMuUNkJyExiMBt5IlFoMyKnr5zhJ4Uspz58WOhBF5QoIZkFyNHIbBAtHwzVAgk5RtndVNsDRN61/mmDqg== + +is-plain-object@^2.0.4: + version "2.0.4" + resolved "https://registry.yarnpkg.com/is-plain-object/-/is-plain-object-2.0.4.tgz#2c163b3fafb1b606d9d17928f05c2a1c38e07677" + integrity sha512-h5PpgXkWitc38BBMYawTYMWJHFZJVnBquFE57xFpjB8pJFiF6gZ+bU+WyI/yqXiFR5mdLsgYNaPe8uao6Uv9Og== + dependencies: + isobject "^3.0.1" + +is-plain-object@^5.0.0: + version "5.0.0" + resolved "https://registry.yarnpkg.com/is-plain-object/-/is-plain-object-5.0.0.tgz#4427f50ab3429e9025ea7d52e9043a9ef4159344" + integrity sha512-VRSzKkbMm5jMDoKLbltAkFQ5Qr7VDiTFGXxYFXXowVj387GeGNOCsOH6Msy00SGZ3Fp84b1Naa1psqgcCIEP5Q== + +is-reference@^3.0.0: + 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-regexp@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/is-regexp/-/is-regexp-1.0.0.tgz#fd2d883545c46bac5a633e7b9a09e87fa2cb5069" + integrity sha512-7zjFAPO4/gwyQAAgRRmqeEeyIICSdmCqa3tsVHMdBzaXXRiqopZL4Cyghg/XulGWrtABTpbnYYzzIRffLkP4oA== + +is-root@^2.1.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/is-root/-/is-root-2.1.0.tgz#809e18129cf1129644302a4f8544035d51984a9c" + integrity sha512-AGOriNp96vNBd3HtU+RzFEc75FfR5ymiYv8E553I71SCeXBiMsVDUtdio1OEFvrPyLIQ9tVR5RxXIFe5PUFjMg== + +is-stream@^2.0.0: + version "2.0.1" + resolved "https://registry.yarnpkg.com/is-stream/-/is-stream-2.0.1.tgz#fac1e3d53b97ad5a9d0ae9cef2389f5810a5c077" + integrity sha512-hFoiJiTl63nn+kstHGBtewWSKnQLpyb155KHheA1l39uvtO9nWIop1p3udqPcUd/xbF1VLMO4n7OI6p7RbngDg== + +is-typedarray@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/is-typedarray/-/is-typedarray-1.0.0.tgz#e479c80858df0c1b11ddda6940f96011fcda4a9a" + integrity sha512-cyA56iCMHAh5CdzjJIa4aohJyeO1YbwLi3Jc35MmRU6poroFjIGZzUzupGiRPOjgHg9TLu43xbpwXk523fMxKA== + +is-wsl@^2.2.0: + version "2.2.0" + resolved "https://registry.yarnpkg.com/is-wsl/-/is-wsl-2.2.0.tgz#74a4c76e77ca9fd3f932f290c17ea326cd157271" + integrity sha512-fKzAra0rGJUUBwGBgNkHZuToZcn+TtXHpeCgmkMJMMYx1sQDYaCSyjJBSCa2nH1DGm7s3n1oBnohoVTBaN7Lww== + dependencies: + is-docker "^2.0.0" + +is-yarn-global@^0.4.0: + version "0.4.1" + resolved "https://registry.yarnpkg.com/is-yarn-global/-/is-yarn-global-0.4.1.tgz#b312d902b313f81e4eaf98b6361ba2b45cd694bb" + integrity sha512-/kppl+R+LO5VmhYSEWARUFjodS25D68gvj8W7z0I7OWhUla5xWu8KL6CtB2V0R6yqhnRgbcaREMr4EEM6htLPQ== + +isarray@0.0.1: + version "0.0.1" + resolved "https://registry.yarnpkg.com/isarray/-/isarray-0.0.1.tgz#8a18acfca9a8f4177e09abfc6038939b05d1eedf" + integrity sha512-D2S+3GLxWH+uhrNEcoh/fnmYeP8E8/zHl644d/jdA0g2uyXvy3sb0qxotE+ne0LtccHknQzWwZEzhak7oJ0COQ== + +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== + +isexe@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/isexe/-/isexe-2.0.0.tgz#e8fbf374dc556ff8947a10dcb0572d633f2cfa10" + integrity sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw== + +isobject@^3.0.1: + version "3.0.1" + resolved "https://registry.yarnpkg.com/isobject/-/isobject-3.0.1.tgz#4e431e92b11a9731636aa1f9c8d1ccbcfdab78df" + integrity sha512-WhB9zCku7EGTj/HQQRz5aUQEUeoQZH2bWcltRErOpymJ4boYE6wL9Tbr23krRPSZ+C5zqNSrSw+Cc7sZZ4b7vg== + +jest-util@^29.7.0: + version "29.7.0" + resolved "https://registry.yarnpkg.com/jest-util/-/jest-util-29.7.0.tgz#23c2b62bfb22be82b44de98055802ff3710fc0bc" + integrity sha512-z6EbKajIpqGKU56y5KBUgy1dt1ihhQJgWzUlZHArA/+X2ad7Cb5iF+AK1EWVL/Bo7Rz9uurpqw6SiBCefUbCGA== + dependencies: + "@jest/types" "^29.6.3" + "@types/node" "*" + chalk "^4.0.0" + ci-info "^3.2.0" + graceful-fs "^4.2.9" + picomatch "^2.2.3" + +jest-worker@^27.4.5: + version "27.5.1" + resolved "https://registry.yarnpkg.com/jest-worker/-/jest-worker-27.5.1.tgz#8d146f0900e8973b106b6f73cc1e9a8cb86f8db0" + integrity sha512-7vuh85V5cdDofPyxn58nrPjBktZo0u9x1g8WtjQol+jZDaE+fhN+cIvTj11GndBnMnyfrUOG1sZQxCdjKh+DKg== + dependencies: + "@types/node" "*" + merge-stream "^2.0.0" + supports-color "^8.0.0" + +jest-worker@^29.1.2: + version "29.7.0" + resolved "https://registry.yarnpkg.com/jest-worker/-/jest-worker-29.7.0.tgz#acad073acbbaeb7262bd5389e1bcf43e10058d4a" + integrity sha512-eIz2msL/EzL9UFTFFx7jBTkeZfku0yUAyZZZmJ93H2TYEiroIx2PQjEXcwYtYl8zXCxb+PAmA2hLIt/6ZEkPHw== + dependencies: + "@types/node" "*" + jest-util "^29.7.0" + merge-stream "^2.0.0" + supports-color "^8.0.0" + +jiti@^1.18.2, jiti@^1.20.0: + version "1.21.0" + resolved "https://registry.yarnpkg.com/jiti/-/jiti-1.21.0.tgz#7c97f8fe045724e136a397f7340475244156105d" + integrity sha512-gFqAIbuKyyso/3G2qhiO2OM6shY6EPP/R0+mkDbyspxKazh8BXDC5FiFsUjlczgdNz/vfra0da2y+aHrusLG/Q== + +joi@^17.11.0, joi@^17.9.2: + version "17.11.0" + resolved "https://registry.yarnpkg.com/joi/-/joi-17.11.0.tgz#aa9da753578ec7720e6f0ca2c7046996ed04fc1a" + integrity sha512-NgB+lZLNoqISVy1rZocE9PZI36bL/77ie924Ri43yEvi9GUUMPeyVIr8KdFTMUlby1p0PBYMk9spIxEUQYqrJQ== + dependencies: + "@hapi/hoek" "^9.0.0" + "@hapi/topo" "^5.0.0" + "@sideway/address" "^4.1.3" + "@sideway/formula" "^3.0.1" + "@sideway/pinpoint" "^2.0.0" + +"js-tokens@^3.0.0 || ^4.0.0", js-tokens@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/js-tokens/-/js-tokens-4.0.0.tgz#19203fb59991df98e3a287050d4647cdeaf32499" + integrity sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ== + +js-yaml@^3.13.1: + version "3.14.1" + resolved "https://registry.yarnpkg.com/js-yaml/-/js-yaml-3.14.1.tgz#dae812fdb3825fa306609a8717383c50c36a0537" + integrity sha512-okMH7OXXJ7YrN9Ok3/SXrnu4iX9yOk+25nqX4imS2npuvTYDmo/QEZoqwZkYaIDk3jVvBOTOIEgEhaLOynBS9g== + dependencies: + argparse "^1.0.7" + esprima "^4.0.0" + +js-yaml@^4.1.0: + version "4.1.0" + resolved "https://registry.yarnpkg.com/js-yaml/-/js-yaml-4.1.0.tgz#c1fb65f8f5017901cdd2c951864ba18458a10602" + integrity sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA== + dependencies: + argparse "^2.0.1" + +jsesc@^2.5.1: + version "2.5.2" + resolved "https://registry.yarnpkg.com/jsesc/-/jsesc-2.5.2.tgz#80564d2e483dacf6e8ef209650a67df3f0c283a4" + integrity sha512-OYu7XEzjkCQ3C5Ps3QIZsQfNpqoJyZZA99wd9aWd05NCtC5pWOkShK2mkL6HXQR6/Cy2lbNdPlZBpuQHXE63gA== + +jsesc@~0.5.0: + version "0.5.0" + resolved "https://registry.yarnpkg.com/jsesc/-/jsesc-0.5.0.tgz#e7dee66e35d6fc16f710fe91d5cf69f70f08911d" + integrity sha512-uZz5UnB7u4T9LvwmFqXii7pZSouaRPorGs5who1Ip7VO0wxanFvBL7GkM6dTHlgX+jhBApRetaWpnDabOeTcnA== + +json-buffer@3.0.1: + version "3.0.1" + resolved "https://registry.yarnpkg.com/json-buffer/-/json-buffer-3.0.1.tgz#9338802a30d3b6605fbe0613e094008ca8c05a13" + integrity sha512-4bV5BfR2mqfQTJm+V5tPPdf+ZpuhiIvTuAB5g8kcrXOZpTT/QwwVRWBywX1ozr6lEuPdbHxwaJlm9G6mI2sfSQ== + +json-parse-even-better-errors@^2.3.0, json-parse-even-better-errors@^2.3.1: + version "2.3.1" + resolved "https://registry.yarnpkg.com/json-parse-even-better-errors/-/json-parse-even-better-errors-2.3.1.tgz#7c47805a94319928e05777405dc12e1f7a4ee02d" + integrity sha512-xyFwyhro/JEof6Ghe2iz2NcXoj2sloNsWr/XsERDK/oiPCfaNhl5ONfp+jQdAZRQQ0IJWNzH9zIZF7li91kh2w== + +json-schema-traverse@^0.4.1: + version "0.4.1" + resolved "https://registry.yarnpkg.com/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz#69f6a87d9513ab8bb8fe63bdb0979c448e684660" + integrity sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg== + +json-schema-traverse@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/json-schema-traverse/-/json-schema-traverse-1.0.0.tgz#ae7bcb3656ab77a73ba5c49bf654f38e6b6860e2" + integrity sha512-NM8/P9n3XjXhIZn1lLhkFaACTOURQXjWhV4BA/RnOv8xvgqtqpAX9IO4mRQxSx1Rlo4tqzeqb0sOlruaOy3dug== + +json5@^2.1.2, json5@^2.2.3: + version "2.2.3" + resolved "https://registry.yarnpkg.com/json5/-/json5-2.2.3.tgz#78cd6f1a19bdc12b73db5ad0c61efd66c1e29283" + integrity sha512-XmOWe7eyHYH14cLdVPoyg+GOH3rYX++KpzrylJwSW98t3Nk+U8XOl8FWKOgwtzdb8lXGf6zYwDUzeHMWfxasyg== + +jsonc-parser@^3.2.0: + version "3.2.0" + resolved "https://registry.yarnpkg.com/jsonc-parser/-/jsonc-parser-3.2.0.tgz#31ff3f4c2b9793f89c67212627c51c6394f88e76" + integrity sha512-gfFQZrcTc8CnKXp6Y4/CBT3fTc0OVuDofpre4aEeEpSBPV5X5v4+Vmx+8snU7RLPrNHPKSgLxGo9YuQzz20o+w== + +jsonfile@^6.0.1: + version "6.1.0" + resolved "https://registry.yarnpkg.com/jsonfile/-/jsonfile-6.1.0.tgz#bc55b2634793c679ec6403094eb13698a6ec0aae" + integrity sha512-5dgndWOriYSm5cnYaJNhalLNDKOqFwyDB/rr1E9ZsGciGvKPs8R2xYGCacuf3z6K1YKDz182fd+fY3cn3pMqXQ== + dependencies: + universalify "^2.0.0" + optionalDependencies: + graceful-fs "^4.1.6" + +keyv@^4.5.3: + version "4.5.4" + resolved "https://registry.yarnpkg.com/keyv/-/keyv-4.5.4.tgz#a879a99e29452f942439f2a405e3af8b31d4de93" + integrity sha512-oxVHkHR/EJf2CNXnWxRLW6mg7JyCCUcG0DtEGmL2ctUo1PNTin1PUil+r/+4r5MpVgC/fn1kjsx7mjSujKqIpw== + dependencies: + json-buffer "3.0.1" + +kind-of@^6.0.0, kind-of@^6.0.2: + version "6.0.3" + resolved "https://registry.yarnpkg.com/kind-of/-/kind-of-6.0.3.tgz#07c05034a6c349fa06e24fa35aa76db4580ce4dd" + integrity sha512-dcS1ul+9tmeD95T+x28/ehLgd9mENa3LsvDTtzm3vyBEO7RPptvAD+t44WVXaUjTBRcrpFeFlC8WCruUR456hw== + +kleur@^3.0.3: + version "3.0.3" + resolved "https://registry.yarnpkg.com/kleur/-/kleur-3.0.3.tgz#a79c9ecc86ee1ce3fa6206d1216c501f147fc07e" + integrity sha512-eTIzlVOSUR+JxdDFepEYcBMtZ9Qqdef+rnzWdRZuMbOywu5tO2w2N7rqjoANZ5k9vywhL6Br1VRjUIgTQx4E8w== + +latest-version@^7.0.0: + version "7.0.0" + resolved "https://registry.yarnpkg.com/latest-version/-/latest-version-7.0.0.tgz#843201591ea81a4d404932eeb61240fe04e9e5da" + integrity sha512-KvNT4XqAMzdcL6ka6Tl3i2lYeFDgXNCuIX+xNx6ZMVR1dFq+idXd9FLKNMOIx0t9mJ9/HudyX4oZWXZQ0UJHeg== + dependencies: + package-json "^8.1.0" + +launch-editor@^2.6.0: + version "2.6.1" + resolved "https://registry.yarnpkg.com/launch-editor/-/launch-editor-2.6.1.tgz#f259c9ef95cbc9425620bbbd14b468fcdb4ffe3c" + integrity sha512-eB/uXmFVpY4zezmGp5XtU21kwo7GBbKB+EQ+UZeWtGb9yAM5xt/Evk+lYH3eRNAtId+ej4u7TYPFZ07w4s7rRw== + dependencies: + picocolors "^1.0.0" + shell-quote "^1.8.1" + +leven@^3.1.0: + version "3.1.0" + resolved "https://registry.yarnpkg.com/leven/-/leven-3.1.0.tgz#77891de834064cccba82ae7842bb6b14a13ed7f2" + integrity sha512-qsda+H8jTaUaN/x5vzW2rzc+8Rw4TAQ/4KjB46IwK5VH+IlVeeeje/EoZRpiXvIqjFgK84QffqPztGI3VBLG1A== + +lilconfig@^2.0.3: + version "2.1.0" + resolved "https://registry.yarnpkg.com/lilconfig/-/lilconfig-2.1.0.tgz#78e23ac89ebb7e1bfbf25b18043de756548e7f52" + integrity sha512-utWOt/GHzuUxnLKxB6dk81RoOeoNeHgbrXiuGk4yyF5qlRz+iIVWu56E2fqGHFrXz0QNUhLB/8nKqvRH66JKGQ== + +lines-and-columns@^1.1.6: + version "1.2.4" + resolved "https://registry.yarnpkg.com/lines-and-columns/-/lines-and-columns-1.2.4.tgz#eca284f75d2965079309dc0ad9255abb2ebc1632" + integrity sha512-7ylylesZQ/PV29jhEDl3Ufjo6ZX7gCqJr5F7PKrqc93v7fzSymt1BpwEU8nAUXs8qzzvqhbjhK5QZg6Mt/HkBg== + +loader-runner@^4.2.0: + version "4.3.0" + resolved "https://registry.yarnpkg.com/loader-runner/-/loader-runner-4.3.0.tgz#c1b4a163b99f614830353b16755e7149ac2314e1" + integrity sha512-3R/1M+yS3j5ou80Me59j7F9IMs4PXs3VqRrm0TU3AbKPxlmpoY1TNscJV/oGJXo8qCatFGTfDbY6W6ipGOYXfg== + +loader-utils@^2.0.0: + version "2.0.4" + resolved "https://registry.yarnpkg.com/loader-utils/-/loader-utils-2.0.4.tgz#8b5cb38b5c34a9a018ee1fc0e6a066d1dfcc528c" + integrity sha512-xXqpXoINfFhgua9xiqD8fPFHgkoq1mmmpE92WlDbm9rNRd/EbRb+Gqf908T2DMfuHjjJlksiK2RbHVOdD/MqSw== + dependencies: + big.js "^5.2.2" + emojis-list "^3.0.0" + json5 "^2.1.2" + +loader-utils@^3.2.0: + version "3.2.1" + resolved "https://registry.yarnpkg.com/loader-utils/-/loader-utils-3.2.1.tgz#4fb104b599daafd82ef3e1a41fb9265f87e1f576" + integrity sha512-ZvFw1KWS3GVyYBYb7qkmRM/WwL2TQQBxgCK62rlvm4WpVQ23Nb4tYjApUlfjrEGvOs7KHEsmyUn75OHZrJMWPw== + +locate-path@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/locate-path/-/locate-path-3.0.0.tgz#dbec3b3ab759758071b58fe59fc41871af21400e" + integrity sha512-7AO748wWnIhNqAuaty2ZWHkQHRSNfPVIsPIfwEOWO22AmaoVrWavlOcMR5nzTLNYvp36X220/maaRsrec1G65A== + dependencies: + p-locate "^3.0.0" + path-exists "^3.0.0" + +locate-path@^6.0.0: + version "6.0.0" + resolved "https://registry.yarnpkg.com/locate-path/-/locate-path-6.0.0.tgz#55321eb309febbc59c4801d931a72452a681d286" + integrity sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw== + dependencies: + p-locate "^5.0.0" + +locate-path@^7.1.0: + version "7.2.0" + resolved "https://registry.yarnpkg.com/locate-path/-/locate-path-7.2.0.tgz#69cb1779bd90b35ab1e771e1f2f89a202c2a8a8a" + integrity sha512-gvVijfZvn7R+2qyPX8mAuKcFGDf6Nc61GdvGafQsHL0sBIxfKzA+usWn4GFC/bk+QdwPUD4kWFJLhElipq+0VA== + dependencies: + p-locate "^6.0.0" + +lodash.curry@^4.0.1: + version "4.1.1" + resolved "https://registry.yarnpkg.com/lodash.curry/-/lodash.curry-4.1.1.tgz#248e36072ede906501d75966200a86dab8b23170" + integrity sha512-/u14pXGviLaweY5JI0IUzgzF2J6Ne8INyzAZjImcryjgkZ+ebruBxy2/JaOOkTqScddcYtakjhSaeemV8lR0tA== + +lodash.debounce@^4.0.8: + version "4.0.8" + resolved "https://registry.yarnpkg.com/lodash.debounce/-/lodash.debounce-4.0.8.tgz#82d79bff30a67c4005ffd5e2515300ad9ca4d7af" + integrity sha512-FT1yDzDYEoYWhnSGnpE/4Kj1fLZkDFyqRb7fNt6FdYOSxlUWAtp42Eh6Wb0rGIv/m9Bgo7x4GhQbm5Ys4SG5ow== + +lodash.flow@^3.3.0: + version "3.5.0" + resolved "https://registry.yarnpkg.com/lodash.flow/-/lodash.flow-3.5.0.tgz#87bf40292b8cf83e4e8ce1a3ae4209e20071675a" + integrity sha512-ff3BX/tSioo+XojX4MOsOMhJw0nZoUEF011LX8g8d3gvjVbxd89cCio4BCXronjxcTUIJUoqKEUA+n4CqvvRPw== + +lodash.memoize@^4.1.2: + version "4.1.2" + resolved "https://registry.yarnpkg.com/lodash.memoize/-/lodash.memoize-4.1.2.tgz#bcc6c49a42a2840ed997f323eada5ecd182e0bfe" + integrity sha512-t7j+NzmgnQzTAYXcsHYLgimltOV1MXHtlOWf6GjL9Kj8GK5FInw5JotxvbOs+IvV1/Dzo04/fCGfLVs7aXb4Ag== + +lodash.uniq@^4.5.0: + version "4.5.0" + resolved "https://registry.yarnpkg.com/lodash.uniq/-/lodash.uniq-4.5.0.tgz#d0225373aeb652adc1bc82e4945339a842754773" + integrity sha512-xfBaXQd9ryd9dlSDvnvI0lvxfLJlYAZzXomUYzLKtUeOQvOP5piqAWuGtrhWeqaXK9hhoM/iyJc5AV+XfsX3HQ== + +lodash@^4.17.20, lodash@^4.17.21: + version "4.17.21" + resolved "https://registry.yarnpkg.com/lodash/-/lodash-4.17.21.tgz#679591c564c3bffaae8454cf0b3df370c3d6911c" + integrity sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg== + +longest-streak@^3.0.0: + version "3.1.0" + resolved "https://registry.yarnpkg.com/longest-streak/-/longest-streak-3.1.0.tgz#62fa67cd958742a1574af9f39866364102d90cd4" + integrity sha512-9Ri+o0JYgehTaVBBDoMqIl8GXtbWg711O3srftcHhZ0dqnETqLaoIK0x17fUw9rFSlK/0NlsKe0Ahhyl5pXE2g== + +loose-envify@^1.0.0, loose-envify@^1.1.0, loose-envify@^1.2.0, loose-envify@^1.3.1, loose-envify@^1.4.0: + version "1.4.0" + resolved "https://registry.yarnpkg.com/loose-envify/-/loose-envify-1.4.0.tgz#71ee51fa7be4caec1a63839f7e682d8132d30caf" + integrity sha512-lyuxPGr/Wfhrlem2CL/UcnUc1zcqKAImBDzukY7Y5F/yQiNdko6+fRLevlw1HgMySw7f611UIY408EtxRSoK3Q== + dependencies: + js-tokens "^3.0.0 || ^4.0.0" + +lower-case@^2.0.2: + version "2.0.2" + resolved "https://registry.yarnpkg.com/lower-case/-/lower-case-2.0.2.tgz#6fa237c63dbdc4a82ca0fd882e4722dc5e634e28" + integrity sha512-7fm3l3NAF9WfN6W3JOmf5drwpVqX78JtoGJ3A6W0a6ZnldM41w2fV5D490psKFTpMds8TJse/eHLFFsNHHjHgg== + dependencies: + tslib "^2.0.3" + +lowercase-keys@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/lowercase-keys/-/lowercase-keys-3.0.0.tgz#c5e7d442e37ead247ae9db117a9d0a467c89d4f2" + integrity sha512-ozCC6gdQ+glXOQsveKD0YsDy8DSQFjDTz4zyzEHNV5+JP5D62LmfDZ6o1cycFx9ouG940M5dE8C8CTewdj2YWQ== + +lru-cache@^5.1.1: + version "5.1.1" + resolved "https://registry.yarnpkg.com/lru-cache/-/lru-cache-5.1.1.tgz#1da27e6710271947695daf6848e847f01d84b920" + integrity sha512-KpNARQA3Iwv+jTA0utUVVbrh+Jlrr1Fv0e56GGzAFOXN7dk/FviaDW8LHmK52DlcH4WP2n6gI8vN1aesBFgo9w== + dependencies: + yallist "^3.0.2" + +lru-cache@^6.0.0: + version "6.0.0" + resolved "https://registry.yarnpkg.com/lru-cache/-/lru-cache-6.0.0.tgz#6d6fe6570ebd96aaf90fcad1dafa3b2566db3a94" + integrity sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA== + dependencies: + yallist "^4.0.0" + +lunr@^2.3.9: + version "2.3.9" + resolved "https://registry.yarnpkg.com/lunr/-/lunr-2.3.9.tgz#18b123142832337dd6e964df1a5a7707b25d35e1" + integrity sha512-zTU3DaZaF3Rt9rhN3uBMGQD3dD2/vFQqnvZCDv4dl5iOzq2IZQqTxu90r4E5J+nP70J3ilqVCrbho2eWaeW8Ow== + +markdown-extensions@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/markdown-extensions/-/markdown-extensions-2.0.0.tgz#34bebc83e9938cae16e0e017e4a9814a8330d3c4" + integrity sha512-o5vL7aDWatOTX8LzaS1WMoaoxIiLRQJuIKKe2wAw6IeULDHaqbiqiggmx+pKvZDb1Sj+pE46Sn1T7lCqfFtg1Q== + +markdown-table@^3.0.0: + version "3.0.3" + resolved "https://registry.yarnpkg.com/markdown-table/-/markdown-table-3.0.3.tgz#e6331d30e493127e031dd385488b5bd326e4a6bd" + integrity sha512-Z1NL3Tb1M9wH4XESsCDEksWoKTdlUafKc4pt0GRwjUyXaCFZ+dc3g2erqB6zm3szA2IUSi7VnPI+o/9jnxh9hw== + +marked@^4.3.0: + version "4.3.0" + resolved "https://registry.yarnpkg.com/marked/-/marked-4.3.0.tgz#796362821b019f734054582038b116481b456cf3" + integrity sha512-PRsaiG84bK+AMvxziE/lCFss8juXjNaWzVbN5tXAm4XjeaS9NAHhop+PjQxz2A9h8Q4M/xGmzP8vqNwy6JeK0A== + +mdast-util-directive@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/mdast-util-directive/-/mdast-util-directive-3.0.0.tgz#3fb1764e705bbdf0afb0d3f889e4404c3e82561f" + integrity sha512-JUpYOqKI4mM3sZcNxmF/ox04XYFFkNwr0CFlrQIkCwbvH0xzMCqkMqAde9wRd80VAhaUrwFwKm2nxretdT1h7Q== + dependencies: + "@types/mdast" "^4.0.0" + "@types/unist" "^3.0.0" + devlop "^1.0.0" + mdast-util-from-markdown "^2.0.0" + mdast-util-to-markdown "^2.0.0" + parse-entities "^4.0.0" + stringify-entities "^4.0.0" + unist-util-visit-parents "^6.0.0" + +mdast-util-find-and-replace@^3.0.0, mdast-util-find-and-replace@^3.0.1: + version "3.0.1" + resolved "https://registry.yarnpkg.com/mdast-util-find-and-replace/-/mdast-util-find-and-replace-3.0.1.tgz#a6fc7b62f0994e973490e45262e4bc07607b04e0" + integrity sha512-SG21kZHGC3XRTSUhtofZkBzZTJNM5ecCi0SK2IMKmSXR8vO3peL+kb1O0z7Zl83jKtutG4k5Wv/W7V3/YHvzPA== + dependencies: + "@types/mdast" "^4.0.0" + escape-string-regexp "^5.0.0" + unist-util-is "^6.0.0" + unist-util-visit-parents "^6.0.0" + +mdast-util-from-markdown@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/mdast-util-from-markdown/-/mdast-util-from-markdown-2.0.0.tgz#52f14815ec291ed061f2922fd14d6689c810cb88" + integrity sha512-n7MTOr/z+8NAX/wmhhDji8O3bRvPTV/U0oTCaZJkjhPSKTPhS3xufVhKGF8s1pJ7Ox4QgoIU7KHseh09S+9rTA== + dependencies: + "@types/mdast" "^4.0.0" + "@types/unist" "^3.0.0" + decode-named-character-reference "^1.0.0" + devlop "^1.0.0" + mdast-util-to-string "^4.0.0" + micromark "^4.0.0" + micromark-util-decode-numeric-character-reference "^2.0.0" + micromark-util-decode-string "^2.0.0" + micromark-util-normalize-identifier "^2.0.0" + micromark-util-symbol "^2.0.0" + micromark-util-types "^2.0.0" + unist-util-stringify-position "^4.0.0" + +mdast-util-frontmatter@^2.0.0: + version "2.0.1" + resolved "https://registry.yarnpkg.com/mdast-util-frontmatter/-/mdast-util-frontmatter-2.0.1.tgz#f5f929eb1eb36c8a7737475c7eb438261f964ee8" + integrity sha512-LRqI9+wdgC25P0URIJY9vwocIzCcksduHQ9OF2joxQoyTNVduwLAFUzjoopuRJbJAReaKrNQKAZKL3uCMugWJA== + dependencies: + "@types/mdast" "^4.0.0" + devlop "^1.0.0" + escape-string-regexp "^5.0.0" + mdast-util-from-markdown "^2.0.0" + mdast-util-to-markdown "^2.0.0" + micromark-extension-frontmatter "^2.0.0" + +mdast-util-gfm-autolink-literal@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/mdast-util-gfm-autolink-literal/-/mdast-util-gfm-autolink-literal-2.0.0.tgz#5baf35407421310a08e68c15e5d8821e8898ba2a" + integrity sha512-FyzMsduZZHSc3i0Px3PQcBT4WJY/X/RCtEJKuybiC6sjPqLv7h1yqAkmILZtuxMSsUyaLUWNp71+vQH2zqp5cg== + dependencies: + "@types/mdast" "^4.0.0" + ccount "^2.0.0" + devlop "^1.0.0" + mdast-util-find-and-replace "^3.0.0" + micromark-util-character "^2.0.0" + +mdast-util-gfm-footnote@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/mdast-util-gfm-footnote/-/mdast-util-gfm-footnote-2.0.0.tgz#25a1753c7d16db8bfd53cd84fe50562bd1e6d6a9" + integrity sha512-5jOT2boTSVkMnQ7LTrd6n/18kqwjmuYqo7JUPe+tRCY6O7dAuTFMtTPauYYrMPpox9hlN0uOx/FL8XvEfG9/mQ== + dependencies: + "@types/mdast" "^4.0.0" + devlop "^1.1.0" + mdast-util-from-markdown "^2.0.0" + mdast-util-to-markdown "^2.0.0" + micromark-util-normalize-identifier "^2.0.0" + +mdast-util-gfm-strikethrough@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/mdast-util-gfm-strikethrough/-/mdast-util-gfm-strikethrough-2.0.0.tgz#d44ef9e8ed283ac8c1165ab0d0dfd058c2764c16" + integrity sha512-mKKb915TF+OC5ptj5bJ7WFRPdYtuHv0yTRxK2tJvi+BDqbkiG7h7u/9SI89nRAYcmap2xHQL9D+QG/6wSrTtXg== + dependencies: + "@types/mdast" "^4.0.0" + mdast-util-from-markdown "^2.0.0" + mdast-util-to-markdown "^2.0.0" + +mdast-util-gfm-table@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/mdast-util-gfm-table/-/mdast-util-gfm-table-2.0.0.tgz#7a435fb6223a72b0862b33afbd712b6dae878d38" + integrity sha512-78UEvebzz/rJIxLvE7ZtDd/vIQ0RHv+3Mh5DR96p7cS7HsBhYIICDBCu8csTNWNO6tBWfqXPWekRuj2FNOGOZg== + dependencies: + "@types/mdast" "^4.0.0" + devlop "^1.0.0" + markdown-table "^3.0.0" + mdast-util-from-markdown "^2.0.0" + mdast-util-to-markdown "^2.0.0" + +mdast-util-gfm-task-list-item@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/mdast-util-gfm-task-list-item/-/mdast-util-gfm-task-list-item-2.0.0.tgz#e68095d2f8a4303ef24094ab642e1047b991a936" + integrity sha512-IrtvNvjxC1o06taBAVJznEnkiHxLFTzgonUdy8hzFVeDun0uTjxxrRGVaNFqkU1wJR3RBPEfsxmU6jDWPofrTQ== + dependencies: + "@types/mdast" "^4.0.0" + devlop "^1.0.0" + mdast-util-from-markdown "^2.0.0" + mdast-util-to-markdown "^2.0.0" + +mdast-util-gfm@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/mdast-util-gfm/-/mdast-util-gfm-3.0.0.tgz#3f2aecc879785c3cb6a81ff3a243dc11eca61095" + integrity sha512-dgQEX5Amaq+DuUqf26jJqSK9qgixgd6rYDHAv4aTBuA92cTknZlKpPfa86Z/s8Dj8xsAQpFfBmPUHWJBWqS4Bw== + dependencies: + mdast-util-from-markdown "^2.0.0" + mdast-util-gfm-autolink-literal "^2.0.0" + mdast-util-gfm-footnote "^2.0.0" + mdast-util-gfm-strikethrough "^2.0.0" + mdast-util-gfm-table "^2.0.0" + mdast-util-gfm-task-list-item "^2.0.0" + mdast-util-to-markdown "^2.0.0" + +mdast-util-mdx-expression@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/mdast-util-mdx-expression/-/mdast-util-mdx-expression-2.0.0.tgz#4968b73724d320a379110d853e943a501bfd9d87" + integrity sha512-fGCu8eWdKUKNu5mohVGkhBXCXGnOTLuFqOvGMvdikr+J1w7lDJgxThOKpwRWzzbyXAU2hhSwsmssOY4yTokluw== + dependencies: + "@types/estree-jsx" "^1.0.0" + "@types/hast" "^3.0.0" + "@types/mdast" "^4.0.0" + devlop "^1.0.0" + mdast-util-from-markdown "^2.0.0" + mdast-util-to-markdown "^2.0.0" + +mdast-util-mdx-jsx@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/mdast-util-mdx-jsx/-/mdast-util-mdx-jsx-3.0.0.tgz#f73631fa5bb7a36712ff1e9cedec0cafed03401c" + integrity sha512-XZuPPzQNBPAlaqsTTgRrcJnyFbSOBovSadFgbFu8SnuNgm+6Bdx1K+IWoitsmj6Lq6MNtI+ytOqwN70n//NaBA== + dependencies: + "@types/estree-jsx" "^1.0.0" + "@types/hast" "^3.0.0" + "@types/mdast" "^4.0.0" + "@types/unist" "^3.0.0" + ccount "^2.0.0" + devlop "^1.1.0" + mdast-util-from-markdown "^2.0.0" + mdast-util-to-markdown "^2.0.0" + parse-entities "^4.0.0" + stringify-entities "^4.0.0" + unist-util-remove-position "^5.0.0" + unist-util-stringify-position "^4.0.0" + vfile-message "^4.0.0" + +mdast-util-mdx@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/mdast-util-mdx/-/mdast-util-mdx-3.0.0.tgz#792f9cf0361b46bee1fdf1ef36beac424a099c41" + integrity sha512-JfbYLAW7XnYTTbUsmpu0kdBUVe+yKVJZBItEjwyYJiDJuZ9w4eeaqks4HQO+R7objWgS2ymV60GYpI14Ug554w== + dependencies: + mdast-util-from-markdown "^2.0.0" + mdast-util-mdx-expression "^2.0.0" + mdast-util-mdx-jsx "^3.0.0" + mdast-util-mdxjs-esm "^2.0.0" + mdast-util-to-markdown "^2.0.0" + +mdast-util-mdxjs-esm@^2.0.0: + version "2.0.1" + resolved "https://registry.yarnpkg.com/mdast-util-mdxjs-esm/-/mdast-util-mdxjs-esm-2.0.1.tgz#019cfbe757ad62dd557db35a695e7314bcc9fa97" + integrity sha512-EcmOpxsZ96CvlP03NghtH1EsLtr0n9Tm4lPUJUBccV9RwUOneqSycg19n5HGzCf+10LozMRSObtVr3ee1WoHtg== + dependencies: + "@types/estree-jsx" "^1.0.0" + "@types/hast" "^3.0.0" + "@types/mdast" "^4.0.0" + devlop "^1.0.0" + mdast-util-from-markdown "^2.0.0" + mdast-util-to-markdown "^2.0.0" + +mdast-util-phrasing@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/mdast-util-phrasing/-/mdast-util-phrasing-4.0.0.tgz#468cbbb277375523de807248b8ad969feb02a5c7" + integrity sha512-xadSsJayQIucJ9n053dfQwVu1kuXg7jCTdYsMK8rqzKZh52nLfSH/k0sAxE0u+pj/zKZX+o5wB+ML5mRayOxFA== + dependencies: + "@types/mdast" "^4.0.0" + unist-util-is "^6.0.0" + +mdast-util-to-hast@^13.0.0: + version "13.0.2" + resolved "https://registry.yarnpkg.com/mdast-util-to-hast/-/mdast-util-to-hast-13.0.2.tgz#74c0a9f014bb2340cae6118f6fccd75467792be7" + integrity sha512-U5I+500EOOw9e3ZrclN3Is3fRpw8c19SMyNZlZ2IS+7vLsNzb2Om11VpIVOR+/0137GhZsFEF6YiKD5+0Hr2Og== + dependencies: + "@types/hast" "^3.0.0" + "@types/mdast" "^4.0.0" + "@ungap/structured-clone" "^1.0.0" + devlop "^1.0.0" + micromark-util-sanitize-uri "^2.0.0" + trim-lines "^3.0.0" + unist-util-position "^5.0.0" + unist-util-visit "^5.0.0" + +mdast-util-to-markdown@^2.0.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/mdast-util-to-markdown/-/mdast-util-to-markdown-2.1.0.tgz#9813f1d6e0cdaac7c244ec8c6dabfdb2102ea2b4" + integrity sha512-SR2VnIEdVNCJbP6y7kVTJgPLifdr8WEU440fQec7qHoHOUz/oJ2jmNRqdDQ3rbiStOXb2mCDGTuwsK5OPUgYlQ== + dependencies: + "@types/mdast" "^4.0.0" + "@types/unist" "^3.0.0" + longest-streak "^3.0.0" + mdast-util-phrasing "^4.0.0" + mdast-util-to-string "^4.0.0" + micromark-util-decode-string "^2.0.0" + unist-util-visit "^5.0.0" + zwitch "^2.0.0" + +mdast-util-to-string@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/mdast-util-to-string/-/mdast-util-to-string-4.0.0.tgz#7a5121475556a04e7eddeb67b264aae79d312814" + integrity sha512-0H44vDimn51F0YwvxSJSm0eCDOJTRlmN0R1yBh4HLj9wiV1Dn0QoXGbvFAWj2hSItVTlCmBF1hqKlIyUBVFLPg== + dependencies: + "@types/mdast" "^4.0.0" + +mdn-data@2.0.14: + version "2.0.14" + resolved "https://registry.yarnpkg.com/mdn-data/-/mdn-data-2.0.14.tgz#7113fc4281917d63ce29b43446f701e68c25ba50" + integrity sha512-dn6wd0uw5GsdswPFfsgMp5NSB0/aDe6fK94YJV/AJDYXL6HVLWBsxeq7js7Ad+mU2K9LAlwpk6kN2D5mwCPVow== + +media-typer@0.3.0: + version "0.3.0" + resolved "https://registry.yarnpkg.com/media-typer/-/media-typer-0.3.0.tgz#8710d7af0aa626f8fffa1ce00168545263255748" + integrity sha512-dq+qelQ9akHpcOl/gUVRTxVIOkAJ1wR3QAvb4RsVjS8oVoFjDGTc679wJYmUmknUF5HwMLOgb5O+a3KxfWapPQ== + +memfs@^3.1.2, memfs@^3.4.3: + version "3.6.0" + resolved "https://registry.yarnpkg.com/memfs/-/memfs-3.6.0.tgz#d7a2110f86f79dd950a8b6df6d57bc984aa185f6" + integrity sha512-EGowvkkgbMcIChjMTMkESFDbZeSh8xZ7kNSF0hAiAN4Jh6jgHCRS0Ga/+C8y6Au+oqpezRHCfPsmJ2+DwAgiwQ== + dependencies: + fs-monkey "^1.0.4" + +merge-descriptors@1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/merge-descriptors/-/merge-descriptors-1.0.1.tgz#b00aaa556dd8b44568150ec9d1b953f3f90cbb61" + integrity sha512-cCi6g3/Zr1iqQi6ySbseM1Xvooa98N0w31jzUYrXPX2xqObmFGHJ0tQ5u74H3mVh7wLouTseZyYIq39g8cNp1w== + +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" + integrity sha512-8q7VEgMJW4J8tcfVPy8g09NcQwZdbwFEqhe/WZkoIzjn/3TGDwtOCYtXGxA3O8tPzpczCCDgv+P2P5y00ZJOOg== + +methods@~1.1.2: + version "1.1.2" + resolved "https://registry.yarnpkg.com/methods/-/methods-1.1.2.tgz#5529a4d67654134edcc5266656835b0f851afcee" + integrity sha512-iclAHeNqNm68zFtnZ0e+1L2yUIdvzNoauKU4WBA3VvH/vPFieF7qfRlwUZU+DA9P9bPXIS90ulxoUoCH23sV2w== + +micromark-core-commonmark@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/micromark-core-commonmark/-/micromark-core-commonmark-2.0.0.tgz#50740201f0ee78c12a675bf3e68ffebc0bf931a3" + integrity sha512-jThOz/pVmAYUtkroV3D5c1osFXAMv9e0ypGDOIZuCeAe91/sD6BoE2Sjzt30yuXtwOYUmySOhMas/PVyh02itA== + dependencies: + decode-named-character-reference "^1.0.0" + devlop "^1.0.0" + micromark-factory-destination "^2.0.0" + micromark-factory-label "^2.0.0" + micromark-factory-space "^2.0.0" + micromark-factory-title "^2.0.0" + micromark-factory-whitespace "^2.0.0" + micromark-util-character "^2.0.0" + micromark-util-chunked "^2.0.0" + micromark-util-classify-character "^2.0.0" + micromark-util-html-tag-name "^2.0.0" + micromark-util-normalize-identifier "^2.0.0" + micromark-util-resolve-all "^2.0.0" + micromark-util-subtokenize "^2.0.0" + micromark-util-symbol "^2.0.0" + micromark-util-types "^2.0.0" + +micromark-extension-directive@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/micromark-extension-directive/-/micromark-extension-directive-3.0.0.tgz#527869de497a6de9024138479091bc885dae076b" + integrity sha512-61OI07qpQrERc+0wEysLHMvoiO3s2R56x5u7glHq2Yqq6EHbH4dW25G9GfDdGCDYqA21KE6DWgNSzxSwHc2hSg== + dependencies: + devlop "^1.0.0" + micromark-factory-space "^2.0.0" + micromark-factory-whitespace "^2.0.0" + micromark-util-character "^2.0.0" + micromark-util-symbol "^2.0.0" + micromark-util-types "^2.0.0" + parse-entities "^4.0.0" + +micromark-extension-frontmatter@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/micromark-extension-frontmatter/-/micromark-extension-frontmatter-2.0.0.tgz#651c52ffa5d7a8eeed687c513cd869885882d67a" + integrity sha512-C4AkuM3dA58cgZha7zVnuVxBhDsbttIMiytjgsM2XbHAB2faRVaHRle40558FBN+DJcrLNCoqG5mlrpdU4cRtg== + dependencies: + fault "^2.0.0" + micromark-util-character "^2.0.0" + micromark-util-symbol "^2.0.0" + micromark-util-types "^2.0.0" + +micromark-extension-gfm-autolink-literal@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/micromark-extension-gfm-autolink-literal/-/micromark-extension-gfm-autolink-literal-2.0.0.tgz#f1e50b42e67d441528f39a67133eddde2bbabfd9" + integrity sha512-rTHfnpt/Q7dEAK1Y5ii0W8bhfJlVJFnJMHIPisfPK3gpVNuOP0VnRl96+YJ3RYWV/P4gFeQoGKNlT3RhuvpqAg== + dependencies: + micromark-util-character "^2.0.0" + micromark-util-sanitize-uri "^2.0.0" + micromark-util-symbol "^2.0.0" + micromark-util-types "^2.0.0" + +micromark-extension-gfm-footnote@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/micromark-extension-gfm-footnote/-/micromark-extension-gfm-footnote-2.0.0.tgz#91afad310065a94b636ab1e9dab2c60d1aab953c" + integrity sha512-6Rzu0CYRKDv3BfLAUnZsSlzx3ak6HAoI85KTiijuKIz5UxZxbUI+pD6oHgw+6UtQuiRwnGRhzMmPRv4smcz0fg== + dependencies: + devlop "^1.0.0" + micromark-core-commonmark "^2.0.0" + micromark-factory-space "^2.0.0" + micromark-util-character "^2.0.0" + micromark-util-normalize-identifier "^2.0.0" + micromark-util-sanitize-uri "^2.0.0" + micromark-util-symbol "^2.0.0" + micromark-util-types "^2.0.0" + +micromark-extension-gfm-strikethrough@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/micromark-extension-gfm-strikethrough/-/micromark-extension-gfm-strikethrough-2.0.0.tgz#6917db8e320da70e39ffbf97abdbff83e6783e61" + integrity sha512-c3BR1ClMp5fxxmwP6AoOY2fXO9U8uFMKs4ADD66ahLTNcwzSCyRVU4k7LPV5Nxo/VJiR4TdzxRQY2v3qIUceCw== + dependencies: + devlop "^1.0.0" + micromark-util-chunked "^2.0.0" + micromark-util-classify-character "^2.0.0" + micromark-util-resolve-all "^2.0.0" + micromark-util-symbol "^2.0.0" + micromark-util-types "^2.0.0" + +micromark-extension-gfm-table@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/micromark-extension-gfm-table/-/micromark-extension-gfm-table-2.0.0.tgz#2cf3fe352d9e089b7ef5fff003bdfe0da29649b7" + integrity sha512-PoHlhypg1ItIucOaHmKE8fbin3vTLpDOUg8KAr8gRCF1MOZI9Nquq2i/44wFvviM4WuxJzc3demT8Y3dkfvYrw== + dependencies: + devlop "^1.0.0" + micromark-factory-space "^2.0.0" + micromark-util-character "^2.0.0" + micromark-util-symbol "^2.0.0" + micromark-util-types "^2.0.0" + +micromark-extension-gfm-tagfilter@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/micromark-extension-gfm-tagfilter/-/micromark-extension-gfm-tagfilter-2.0.0.tgz#f26d8a7807b5985fba13cf61465b58ca5ff7dc57" + integrity sha512-xHlTOmuCSotIA8TW1mDIM6X2O1SiX5P9IuDtqGonFhEK0qgRI4yeC6vMxEV2dgyr2TiD+2PQ10o+cOhdVAcwfg== + dependencies: + micromark-util-types "^2.0.0" + +micromark-extension-gfm-task-list-item@^2.0.0: + version "2.0.1" + resolved "https://registry.yarnpkg.com/micromark-extension-gfm-task-list-item/-/micromark-extension-gfm-task-list-item-2.0.1.tgz#ee8b208f1ced1eb9fb11c19a23666e59d86d4838" + integrity sha512-cY5PzGcnULaN5O7T+cOzfMoHjBW7j+T9D2sucA5d/KbsBTPcYdebm9zUd9zzdgJGCwahV+/W78Z3nbulBYVbTw== + dependencies: + devlop "^1.0.0" + micromark-factory-space "^2.0.0" + micromark-util-character "^2.0.0" + micromark-util-symbol "^2.0.0" + micromark-util-types "^2.0.0" + +micromark-extension-gfm@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/micromark-extension-gfm/-/micromark-extension-gfm-3.0.0.tgz#3e13376ab95dd7a5cfd0e29560dfe999657b3c5b" + integrity sha512-vsKArQsicm7t0z2GugkCKtZehqUm31oeGBV/KVSorWSy8ZlNAv7ytjFhvaryUiCUJYqs+NoE6AFhpQvBTM6Q4w== + dependencies: + micromark-extension-gfm-autolink-literal "^2.0.0" + micromark-extension-gfm-footnote "^2.0.0" + micromark-extension-gfm-strikethrough "^2.0.0" + micromark-extension-gfm-table "^2.0.0" + micromark-extension-gfm-tagfilter "^2.0.0" + micromark-extension-gfm-task-list-item "^2.0.0" + micromark-util-combine-extensions "^2.0.0" + micromark-util-types "^2.0.0" + +micromark-extension-mdx-expression@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/micromark-extension-mdx-expression/-/micromark-extension-mdx-expression-3.0.0.tgz#1407b9ce69916cf5e03a196ad9586889df25302a" + integrity sha512-sI0nwhUDz97xyzqJAbHQhp5TfaxEvZZZ2JDqUo+7NvyIYG6BZ5CPPqj2ogUoPJlmXHBnyZUzISg9+oUmU6tUjQ== + dependencies: + "@types/estree" "^1.0.0" + devlop "^1.0.0" + micromark-factory-mdx-expression "^2.0.0" + micromark-factory-space "^2.0.0" + micromark-util-character "^2.0.0" + micromark-util-events-to-acorn "^2.0.0" + micromark-util-symbol "^2.0.0" + micromark-util-types "^2.0.0" + +micromark-extension-mdx-jsx@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/micromark-extension-mdx-jsx/-/micromark-extension-mdx-jsx-3.0.0.tgz#4aba0797c25efb2366a3fd2d367c6b1c1159f4f5" + integrity sha512-uvhhss8OGuzR4/N17L1JwvmJIpPhAd8oByMawEKx6NVdBCbesjH4t+vjEp3ZXft9DwvlKSD07fCeI44/N0Vf2w== + dependencies: + "@types/acorn" "^4.0.0" + "@types/estree" "^1.0.0" + devlop "^1.0.0" + estree-util-is-identifier-name "^3.0.0" + micromark-factory-mdx-expression "^2.0.0" + micromark-factory-space "^2.0.0" + micromark-util-character "^2.0.0" + micromark-util-symbol "^2.0.0" + micromark-util-types "^2.0.0" + vfile-message "^4.0.0" + +micromark-extension-mdx-md@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/micromark-extension-mdx-md/-/micromark-extension-mdx-md-2.0.0.tgz#1d252881ea35d74698423ab44917e1f5b197b92d" + integrity sha512-EpAiszsB3blw4Rpba7xTOUptcFeBFi+6PY8VnJ2hhimH+vCQDirWgsMpz7w1XcZE7LVrSAUGb9VJpG9ghlYvYQ== + dependencies: + micromark-util-types "^2.0.0" + +micromark-extension-mdxjs-esm@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/micromark-extension-mdxjs-esm/-/micromark-extension-mdxjs-esm-3.0.0.tgz#de21b2b045fd2059bd00d36746081de38390d54a" + integrity sha512-DJFl4ZqkErRpq/dAPyeWp15tGrcrrJho1hKK5uBS70BCtfrIFg81sqcTVu3Ta+KD1Tk5vAtBNElWxtAa+m8K9A== + dependencies: + "@types/estree" "^1.0.0" + devlop "^1.0.0" + micromark-core-commonmark "^2.0.0" + micromark-util-character "^2.0.0" + micromark-util-events-to-acorn "^2.0.0" + micromark-util-symbol "^2.0.0" + micromark-util-types "^2.0.0" + unist-util-position-from-estree "^2.0.0" + vfile-message "^4.0.0" + +micromark-extension-mdxjs@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/micromark-extension-mdxjs/-/micromark-extension-mdxjs-3.0.0.tgz#b5a2e0ed449288f3f6f6c544358159557549de18" + integrity sha512-A873fJfhnJ2siZyUrJ31l34Uqwy4xIFmvPY1oj+Ean5PHcPBYzEsvqvWGaWcfEIr11O5Dlw3p2y0tZWpKHDejQ== + dependencies: + acorn "^8.0.0" + acorn-jsx "^5.0.0" + micromark-extension-mdx-expression "^3.0.0" + micromark-extension-mdx-jsx "^3.0.0" + micromark-extension-mdx-md "^2.0.0" + micromark-extension-mdxjs-esm "^3.0.0" + micromark-util-combine-extensions "^2.0.0" + micromark-util-types "^2.0.0" + +micromark-factory-destination@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/micromark-factory-destination/-/micromark-factory-destination-2.0.0.tgz#857c94debd2c873cba34e0445ab26b74f6a6ec07" + integrity sha512-j9DGrQLm/Uhl2tCzcbLhy5kXsgkHUrjJHg4fFAeoMRwJmJerT9aw4FEhIbZStWN8A3qMwOp1uzHr4UL8AInxtA== + dependencies: + micromark-util-character "^2.0.0" + micromark-util-symbol "^2.0.0" + micromark-util-types "^2.0.0" + +micromark-factory-label@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/micromark-factory-label/-/micromark-factory-label-2.0.0.tgz#17c5c2e66ce39ad6f4fc4cbf40d972f9096f726a" + integrity sha512-RR3i96ohZGde//4WSe/dJsxOX6vxIg9TimLAS3i4EhBAFx8Sm5SmqVfR8E87DPSR31nEAjZfbt91OMZWcNgdZw== + dependencies: + devlop "^1.0.0" + micromark-util-character "^2.0.0" + micromark-util-symbol "^2.0.0" + micromark-util-types "^2.0.0" + +micromark-factory-mdx-expression@^2.0.0: + version "2.0.1" + resolved "https://registry.yarnpkg.com/micromark-factory-mdx-expression/-/micromark-factory-mdx-expression-2.0.1.tgz#f2a9724ce174f1751173beb2c1f88062d3373b1b" + integrity sha512-F0ccWIUHRLRrYp5TC9ZYXmZo+p2AM13ggbsW4T0b5CRKP8KHVRB8t4pwtBgTxtjRmwrK0Irwm7vs2JOZabHZfg== + dependencies: + "@types/estree" "^1.0.0" + devlop "^1.0.0" + micromark-util-character "^2.0.0" + micromark-util-events-to-acorn "^2.0.0" + micromark-util-symbol "^2.0.0" + micromark-util-types "^2.0.0" + unist-util-position-from-estree "^2.0.0" + vfile-message "^4.0.0" + +micromark-factory-space@^1.0.0: + version "1.1.0" + resolved "https://registry.yarnpkg.com/micromark-factory-space/-/micromark-factory-space-1.1.0.tgz#c8f40b0640a0150751d3345ed885a080b0d15faf" + integrity sha512-cRzEj7c0OL4Mw2v6nwzttyOZe8XY/Z8G0rzmWQZTBi/jjwyw/U4uqKtUORXQrR5bAZZnbTI/feRV/R7hc4jQYQ== + dependencies: + micromark-util-character "^1.0.0" + micromark-util-types "^1.0.0" + +micromark-factory-space@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/micromark-factory-space/-/micromark-factory-space-2.0.0.tgz#5e7afd5929c23b96566d0e1ae018ae4fcf81d030" + integrity sha512-TKr+LIDX2pkBJXFLzpyPyljzYK3MtmllMUMODTQJIUfDGncESaqB90db9IAUcz4AZAJFdd8U9zOp9ty1458rxg== + dependencies: + micromark-util-character "^2.0.0" + micromark-util-types "^2.0.0" + +micromark-factory-title@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/micromark-factory-title/-/micromark-factory-title-2.0.0.tgz#726140fc77892af524705d689e1cf06c8a83ea95" + integrity sha512-jY8CSxmpWLOxS+t8W+FG3Xigc0RDQA9bKMY/EwILvsesiRniiVMejYTE4wumNc2f4UbAa4WsHqe3J1QS1sli+A== + dependencies: + micromark-factory-space "^2.0.0" + micromark-util-character "^2.0.0" + micromark-util-symbol "^2.0.0" + micromark-util-types "^2.0.0" + +micromark-factory-whitespace@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/micromark-factory-whitespace/-/micromark-factory-whitespace-2.0.0.tgz#9e92eb0f5468083381f923d9653632b3cfb5f763" + integrity sha512-28kbwaBjc5yAI1XadbdPYHX/eDnqaUFVikLwrO7FDnKG7lpgxnvk/XGRhX/PN0mOZ+dBSZ+LgunHS+6tYQAzhA== + dependencies: + micromark-factory-space "^2.0.0" + micromark-util-character "^2.0.0" + micromark-util-symbol "^2.0.0" + micromark-util-types "^2.0.0" + +micromark-util-character@^1.0.0, micromark-util-character@^1.1.0: + version "1.2.0" + resolved "https://registry.yarnpkg.com/micromark-util-character/-/micromark-util-character-1.2.0.tgz#4fedaa3646db249bc58caeb000eb3549a8ca5dcc" + integrity sha512-lXraTwcX3yH/vMDaFWCQJP1uIszLVebzUa3ZHdrgxr7KEU/9mL4mVgCpGbyhvNLNlauROiNUq7WN5u7ndbY6xg== + dependencies: + micromark-util-symbol "^1.0.0" + micromark-util-types "^1.0.0" + +micromark-util-character@^2.0.0: + version "2.0.1" + resolved "https://registry.yarnpkg.com/micromark-util-character/-/micromark-util-character-2.0.1.tgz#52b824c2e2633b6fb33399d2ec78ee2a90d6b298" + integrity sha512-3wgnrmEAJ4T+mGXAUfMvMAbxU9RDG43XmGce4j6CwPtVxB3vfwXSZ6KhFwDzZ3mZHhmPimMAXg71veiBGzeAZw== + dependencies: + micromark-util-symbol "^2.0.0" + micromark-util-types "^2.0.0" + +micromark-util-chunked@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/micromark-util-chunked/-/micromark-util-chunked-2.0.0.tgz#e51f4db85fb203a79dbfef23fd41b2f03dc2ef89" + integrity sha512-anK8SWmNphkXdaKgz5hJvGa7l00qmcaUQoMYsBwDlSKFKjc6gjGXPDw3FNL3Nbwq5L8gE+RCbGqTw49FK5Qyvg== + dependencies: + micromark-util-symbol "^2.0.0" + +micromark-util-classify-character@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/micromark-util-classify-character/-/micromark-util-classify-character-2.0.0.tgz#8c7537c20d0750b12df31f86e976d1d951165f34" + integrity sha512-S0ze2R9GH+fu41FA7pbSqNWObo/kzwf8rN/+IGlW/4tC6oACOs8B++bh+i9bVyNnwCcuksbFwsBme5OCKXCwIw== + dependencies: + micromark-util-character "^2.0.0" + micromark-util-symbol "^2.0.0" + micromark-util-types "^2.0.0" + +micromark-util-combine-extensions@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/micromark-util-combine-extensions/-/micromark-util-combine-extensions-2.0.0.tgz#75d6ab65c58b7403616db8d6b31315013bfb7ee5" + integrity sha512-vZZio48k7ON0fVS3CUgFatWHoKbbLTK/rT7pzpJ4Bjp5JjkZeasRfrS9wsBdDJK2cJLHMckXZdzPSSr1B8a4oQ== + dependencies: + micromark-util-chunked "^2.0.0" + micromark-util-types "^2.0.0" + +micromark-util-decode-numeric-character-reference@^2.0.0: + version "2.0.1" + resolved "https://registry.yarnpkg.com/micromark-util-decode-numeric-character-reference/-/micromark-util-decode-numeric-character-reference-2.0.1.tgz#2698bbb38f2a9ba6310e359f99fcb2b35a0d2bd5" + integrity sha512-bmkNc7z8Wn6kgjZmVHOX3SowGmVdhYS7yBpMnuMnPzDq/6xwVA604DuOXMZTO1lvq01g+Adfa0pE2UKGlxL1XQ== + dependencies: + micromark-util-symbol "^2.0.0" + +micromark-util-decode-string@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/micromark-util-decode-string/-/micromark-util-decode-string-2.0.0.tgz#7dfa3a63c45aecaa17824e656bcdb01f9737154a" + integrity sha512-r4Sc6leeUTn3P6gk20aFMj2ntPwn6qpDZqWvYmAG6NgvFTIlj4WtrAudLi65qYoaGdXYViXYw2pkmn7QnIFasA== + dependencies: + decode-named-character-reference "^1.0.0" + micromark-util-character "^2.0.0" + micromark-util-decode-numeric-character-reference "^2.0.0" + micromark-util-symbol "^2.0.0" + +micromark-util-encode@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/micromark-util-encode/-/micromark-util-encode-2.0.0.tgz#0921ac7953dc3f1fd281e3d1932decfdb9382ab1" + integrity sha512-pS+ROfCXAGLWCOc8egcBvT0kf27GoWMqtdarNfDcjb6YLuV5cM3ioG45Ys2qOVqeqSbjaKg72vU+Wby3eddPsA== + +micromark-util-events-to-acorn@^2.0.0: + version "2.0.2" + resolved "https://registry.yarnpkg.com/micromark-util-events-to-acorn/-/micromark-util-events-to-acorn-2.0.2.tgz#4275834f5453c088bd29cd72dfbf80e3327cec07" + integrity sha512-Fk+xmBrOv9QZnEDguL9OI9/NQQp6Hz4FuQ4YmCb/5V7+9eAh1s6AYSvL20kHkD67YIg7EpE54TiSlcsf3vyZgA== + dependencies: + "@types/acorn" "^4.0.0" + "@types/estree" "^1.0.0" + "@types/unist" "^3.0.0" + devlop "^1.0.0" + estree-util-visit "^2.0.0" + micromark-util-symbol "^2.0.0" + micromark-util-types "^2.0.0" + vfile-message "^4.0.0" + +micromark-util-html-tag-name@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/micromark-util-html-tag-name/-/micromark-util-html-tag-name-2.0.0.tgz#ae34b01cbe063363847670284c6255bb12138ec4" + integrity sha512-xNn4Pqkj2puRhKdKTm8t1YHC/BAjx6CEwRFXntTaRf/x16aqka6ouVoutm+QdkISTlT7e2zU7U4ZdlDLJd2Mcw== + +micromark-util-normalize-identifier@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/micromark-util-normalize-identifier/-/micromark-util-normalize-identifier-2.0.0.tgz#91f9a4e65fe66cc80c53b35b0254ad67aa431d8b" + integrity sha512-2xhYT0sfo85FMrUPtHcPo2rrp1lwbDEEzpx7jiH2xXJLqBuy4H0GgXk5ToU8IEwoROtXuL8ND0ttVa4rNqYK3w== + dependencies: + micromark-util-symbol "^2.0.0" + +micromark-util-resolve-all@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/micromark-util-resolve-all/-/micromark-util-resolve-all-2.0.0.tgz#189656e7e1a53d0c86a38a652b284a252389f364" + integrity sha512-6KU6qO7DZ7GJkaCgwBNtplXCvGkJToU86ybBAUdavvgsCiG8lSSvYxr9MhwmQ+udpzywHsl4RpGJsYWG1pDOcA== + dependencies: + micromark-util-types "^2.0.0" + +micromark-util-sanitize-uri@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/micromark-util-sanitize-uri/-/micromark-util-sanitize-uri-2.0.0.tgz#ec8fbf0258e9e6d8f13d9e4770f9be64342673de" + integrity sha512-WhYv5UEcZrbAtlsnPuChHUAsu/iBPOVaEVsntLBIdpibO0ddy8OzavZz3iL2xVvBZOpolujSliP65Kq0/7KIYw== + dependencies: + micromark-util-character "^2.0.0" + micromark-util-encode "^2.0.0" + micromark-util-symbol "^2.0.0" + +micromark-util-subtokenize@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/micromark-util-subtokenize/-/micromark-util-subtokenize-2.0.0.tgz#9f412442d77e0c5789ffdf42377fa8a2bcbdf581" + integrity sha512-vc93L1t+gpR3p8jxeVdaYlbV2jTYteDje19rNSS/H5dlhxUYll5Fy6vJ2cDwP8RnsXi818yGty1ayP55y3W6fg== + dependencies: + devlop "^1.0.0" + micromark-util-chunked "^2.0.0" + micromark-util-symbol "^2.0.0" + micromark-util-types "^2.0.0" + +micromark-util-symbol@^1.0.0, micromark-util-symbol@^1.0.1: + version "1.1.0" + resolved "https://registry.yarnpkg.com/micromark-util-symbol/-/micromark-util-symbol-1.1.0.tgz#813cd17837bdb912d069a12ebe3a44b6f7063142" + integrity sha512-uEjpEYY6KMs1g7QfJ2eX1SQEV+ZT4rUD3UcF6l57acZvLNK7PBZL+ty82Z1qhK1/yXIY4bdx04FKMgR0g4IAag== + +micromark-util-symbol@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/micromark-util-symbol/-/micromark-util-symbol-2.0.0.tgz#12225c8f95edf8b17254e47080ce0862d5db8044" + integrity sha512-8JZt9ElZ5kyTnO94muPxIGS8oyElRJaiJO8EzV6ZSyGQ1Is8xwl4Q45qU5UOg+bGH4AikWziz0iN4sFLWs8PGw== + +micromark-util-types@^1.0.0: + version "1.1.0" + resolved "https://registry.yarnpkg.com/micromark-util-types/-/micromark-util-types-1.1.0.tgz#e6676a8cae0bb86a2171c498167971886cb7e283" + integrity sha512-ukRBgie8TIAcacscVHSiddHjO4k/q3pnedmzMQ4iwDcK0FtFCohKOlFbaOL/mPgfnPsL3C1ZyxJa4sbWrBl3jg== + +micromark-util-types@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/micromark-util-types/-/micromark-util-types-2.0.0.tgz#63b4b7ffeb35d3ecf50d1ca20e68fc7caa36d95e" + integrity sha512-oNh6S2WMHWRZrmutsRmDDfkzKtxF+bc2VxLC9dvtrDIRFln627VsFP6fLMgTryGDljgLPjkrzQSDcPrjPyDJ5w== + +micromark@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/micromark/-/micromark-4.0.0.tgz#84746a249ebd904d9658cfabc1e8e5f32cbc6249" + integrity sha512-o/sd0nMof8kYff+TqcDx3VSrgBTcZpSvYcAHIfHhv5VAuNmisCxjhx6YmxS8PFEpb9z5WKWKPdzf0jM23ro3RQ== + dependencies: + "@types/debug" "^4.0.0" + debug "^4.0.0" + decode-named-character-reference "^1.0.0" + devlop "^1.0.0" + micromark-core-commonmark "^2.0.0" + micromark-factory-space "^2.0.0" + micromark-util-character "^2.0.0" + micromark-util-chunked "^2.0.0" + micromark-util-combine-extensions "^2.0.0" + micromark-util-decode-numeric-character-reference "^2.0.0" + micromark-util-encode "^2.0.0" + micromark-util-normalize-identifier "^2.0.0" + micromark-util-resolve-all "^2.0.0" + micromark-util-sanitize-uri "^2.0.0" + micromark-util-subtokenize "^2.0.0" + micromark-util-symbol "^2.0.0" + micromark-util-types "^2.0.0" + +micromatch@^4.0.2, micromatch@^4.0.4, micromatch@^4.0.5: + version "4.0.5" + resolved "https://registry.yarnpkg.com/micromatch/-/micromatch-4.0.5.tgz#bc8999a7cbbf77cdc89f132f6e467051b49090c6" + integrity sha512-DMy+ERcEW2q8Z2Po+WNXuw3c5YaUSFjAO5GsJqfEl7UjvtIuFKO6ZrKvcItdy98dwFI2N1tg3zNIdKaQT+aNdA== + dependencies: + braces "^3.0.2" + picomatch "^2.3.1" + +mime-db@1.52.0, "mime-db@>= 1.43.0 < 2": + version "1.52.0" + resolved "https://registry.yarnpkg.com/mime-db/-/mime-db-1.52.0.tgz#bbabcdc02859f4987301c856e3387ce5ec43bf70" + integrity sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg== + +mime-db@~1.33.0: + version "1.33.0" + resolved "https://registry.yarnpkg.com/mime-db/-/mime-db-1.33.0.tgz#a3492050a5cb9b63450541e39d9788d2272783db" + integrity sha512-BHJ/EKruNIqJf/QahvxwQZXKygOQ256myeN/Ew+THcAa5q+PjyTTMMeNQC4DZw5AwfvelsUrA6B67NKMqXDbzQ== + +mime-types@2.1.18: + version "2.1.18" + resolved "https://registry.yarnpkg.com/mime-types/-/mime-types-2.1.18.tgz#6f323f60a83d11146f831ff11fd66e2fe5503bb8" + integrity sha512-lc/aahn+t4/SWV/qcmumYjymLsWfN3ELhpmVuUFjgsORruuZPVSwAQryq+HHGvO/SI2KVX26bx+En+zhM8g8hQ== + dependencies: + mime-db "~1.33.0" + +mime-types@^2.1.12, mime-types@^2.1.27, mime-types@^2.1.31, mime-types@~2.1.17, mime-types@~2.1.24, mime-types@~2.1.34: + version "2.1.35" + resolved "https://registry.yarnpkg.com/mime-types/-/mime-types-2.1.35.tgz#381a871b62a734450660ae3deee44813f70d959a" + integrity sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw== + dependencies: + mime-db "1.52.0" + +mime@1.6.0: + version "1.6.0" + resolved "https://registry.yarnpkg.com/mime/-/mime-1.6.0.tgz#32cd9e5c64553bd58d19a568af452acff04981b1" + integrity sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg== + +mimic-fn@^2.1.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/mimic-fn/-/mimic-fn-2.1.0.tgz#7ed2c2ccccaf84d3ffcb7a69b57711fc2083401b" + integrity sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg== + +mimic-response@^3.1.0: + version "3.1.0" + resolved "https://registry.yarnpkg.com/mimic-response/-/mimic-response-3.1.0.tgz#2d1d59af9c1b129815accc2c46a022a5ce1fa3c9" + integrity sha512-z0yWI+4FDrrweS8Zmt4Ej5HdJmky15+L2e6Wgn3+iK5fWzb6T3fhNFq2+MeTRb064c6Wr4N/wv0DzQTjNzHNGQ== + +mimic-response@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/mimic-response/-/mimic-response-4.0.0.tgz#35468b19e7c75d10f5165ea25e75a5ceea7cf70f" + integrity sha512-e5ISH9xMYU0DzrT+jl8q2ze9D6eWBto+I8CNpe+VI+K2J/F/k3PdkdTdz4wvGVH4NTpo+NRYTVIuMQEMMcsLqg== + +mini-css-extract-plugin@^2.7.6: + version "2.7.6" + resolved "https://registry.yarnpkg.com/mini-css-extract-plugin/-/mini-css-extract-plugin-2.7.6.tgz#282a3d38863fddcd2e0c220aaed5b90bc156564d" + integrity sha512-Qk7HcgaPkGG6eD77mLvZS1nmxlao3j+9PkrT9Uc7HAE1id3F41+DdBRYRYkbyfNRGzm8/YWtzhw7nVPmwhqTQw== + dependencies: + schema-utils "^4.0.0" + +minimalistic-assert@^1.0.0: + 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== + +minimatch@3.1.2, minimatch@^3.0.4, minimatch@^3.0.5, minimatch@^3.1.1: + version "3.1.2" + resolved "https://registry.yarnpkg.com/minimatch/-/minimatch-3.1.2.tgz#19cd194bfd3e428f049a70817c038d89ab4be35b" + integrity sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw== + dependencies: + brace-expansion "^1.1.7" + +minimatch@^9.0.3: + version "9.0.3" + resolved "https://registry.yarnpkg.com/minimatch/-/minimatch-9.0.3.tgz#a6e00c3de44c3a542bfaae70abfc22420a6da825" + integrity sha512-RHiac9mvaRw0x3AYRgDC1CxAP7HTcNrrECeA8YYJeWnpo+2Q5CegtZjaotWTWxDG3UeGA1coE05iH1mPjT/2mg== + dependencies: + brace-expansion "^2.0.1" + +minimist@^1.2.0, minimist@^1.2.5, minimist@^1.2.8: + version "1.2.8" + resolved "https://registry.yarnpkg.com/minimist/-/minimist-1.2.8.tgz#c1a464e7693302e082a075cee0c057741ac4772c" + integrity sha512-2yyAR8qBkN3YuheJanUpWC5U3bb5osDywNB8RzDVlDwDHbocAJveqqj1u8+SVD7jkWT4yvsHCpWqqWqAxb0zCA== + +mrmime@^1.0.0: + version "1.0.1" + resolved "https://registry.yarnpkg.com/mrmime/-/mrmime-1.0.1.tgz#5f90c825fad4bdd41dc914eff5d1a8cfdaf24f27" + integrity sha512-hzzEagAgDyoU1Q6yg5uI+AorQgdvMCur3FcKf7NhMKWsaYg+RnbTyHRa/9IlLF9rf455MOCtcqqrQQ83pPP7Uw== + +ms@2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/ms/-/ms-2.0.0.tgz#5608aeadfc00be6c2901df5f9861788de0d597c8" + integrity sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A== + +ms@2.1.2: + version "2.1.2" + resolved "https://registry.yarnpkg.com/ms/-/ms-2.1.2.tgz#d09d1f357b443f493382a8eb3ccd183872ae6009" + integrity sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w== + +ms@2.1.3: + version "2.1.3" + resolved "https://registry.yarnpkg.com/ms/-/ms-2.1.3.tgz#574c8138ce1d2b5861f0b44579dbadd60c6615b2" + integrity sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA== + +multicast-dns@^7.2.5: + version "7.2.5" + resolved "https://registry.yarnpkg.com/multicast-dns/-/multicast-dns-7.2.5.tgz#77eb46057f4d7adbd16d9290fa7299f6fa64cced" + integrity sha512-2eznPJP8z2BFLX50tf0LuODrpINqP1RVIm/CObbTcBRITQgmC/TjcREF1NeTBzIcR5XO/ukWo+YHOjBbFwIupg== + dependencies: + dns-packet "^5.2.2" + thunky "^1.0.2" + +nanoid@^3.3.6: + version "3.3.7" + resolved "https://registry.yarnpkg.com/nanoid/-/nanoid-3.3.7.tgz#d0c301a691bc8d54efa0a2226ccf3fe2fd656bd8" + integrity sha512-eSRppjcPIatRIMC1U6UngP8XFcz8MQWGQdt1MTBQ7NaAmvXDfvNxbvWV3x2y6CdEUciCSsDHDQZbhYaB8QEo2g== + +negotiator@0.6.3: + version "0.6.3" + resolved "https://registry.yarnpkg.com/negotiator/-/negotiator-0.6.3.tgz#58e323a72fedc0d6f9cd4d31fe49f51479590ccd" + integrity sha512-+EUsqGPLsM+j/zdChZjsnX51g4XrHFOIXwfnCVPGlQk/k5giakcKsuxCObBRu6DSm9opw/O6slWbJdghQM4bBg== + +neo-async@^2.6.2: + version "2.6.2" + resolved "https://registry.yarnpkg.com/neo-async/-/neo-async-2.6.2.tgz#b4aafb93e3aeb2d8174ca53cf163ab7d7308305f" + integrity sha512-Yd3UES5mWCSqR+qNT93S3UoYUkqAZ9lLg8a7g9rimsWmYGK8cVToA4/sF3RrshdyV3sAGMXVUmpMYOw+dLpOuw== + +no-case@^3.0.4: + version "3.0.4" + resolved "https://registry.yarnpkg.com/no-case/-/no-case-3.0.4.tgz#d361fd5c9800f558551a8369fc0dcd4662b6124d" + integrity sha512-fgAN3jGAh+RoxUGZHTSOLJIqUc2wmoBwGR4tbpNAKmmovFoWq0OdRkb0VkldReO2a2iBT/OEulG9XSUc10r3zg== + dependencies: + lower-case "^2.0.2" + tslib "^2.0.3" + +node-emoji@^2.1.0: + version "2.1.3" + resolved "https://registry.yarnpkg.com/node-emoji/-/node-emoji-2.1.3.tgz#93cfabb5cc7c3653aa52f29d6ffb7927d8047c06" + integrity sha512-E2WEOVsgs7O16zsURJ/eH8BqhF029wGpEOnv7Urwdo2wmQanOACwJQh0devF9D9RhoZru0+9JXIS0dBXIAz+lA== + dependencies: + "@sindresorhus/is" "^4.6.0" + char-regex "^1.0.2" + emojilib "^2.4.0" + skin-tone "^2.0.0" + +node-fetch@^2.6.12: + version "2.7.0" + resolved "https://registry.yarnpkg.com/node-fetch/-/node-fetch-2.7.0.tgz#d0f0fa6e3e2dc1d27efcd8ad99d550bda94d187d" + integrity sha512-c4FRfUm/dbcWZ7U+1Wq0AwCyFL+3nt2bEw05wfxSz+DWpWsitgmSgYmy2dQdWyKC1694ELPqMs/YzUSNozLt8A== + dependencies: + whatwg-url "^5.0.0" + +node-forge@^1: + version "1.3.1" + resolved "https://registry.yarnpkg.com/node-forge/-/node-forge-1.3.1.tgz#be8da2af243b2417d5f646a770663a92b7e9ded3" + integrity sha512-dPEtOeMvF9VMcYV/1Wb8CPoVAXtp6MKMlcbAt4ddqmGqUJ6fQZFXkNZNkNlfevtNkGtaSoXf/vNNNSvgrdXwtA== + +node-releases@^2.0.13: + version "2.0.13" + resolved "https://registry.yarnpkg.com/node-releases/-/node-releases-2.0.13.tgz#d5ed1627c23e3461e819b02e57b75e4899b1c81d" + integrity sha512-uYr7J37ae/ORWdZeQ1xxMJe3NtdmqMC/JZK+geofDrkLUApKRHPd18/TxtBOJ4A0/+uUIliorNrfYV6s1b02eQ== + +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" + integrity sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA== + +normalize-range@^0.1.2: + version "0.1.2" + resolved "https://registry.yarnpkg.com/normalize-range/-/normalize-range-0.1.2.tgz#2d10c06bdfd312ea9777695a4d28439456b75942" + integrity sha512-bdok/XvKII3nUpklnV6P2hxtMNrCboOjAcyBuQnWEhO665FwrSNRxU+AqpsyvO6LgGYPspN+lu5CLtw4jPRKNA== + +normalize-url@^6.0.1: + version "6.1.0" + resolved "https://registry.yarnpkg.com/normalize-url/-/normalize-url-6.1.0.tgz#40d0885b535deffe3f3147bec877d05fe4c5668a" + integrity sha512-DlL+XwOy3NxAQ8xuC0okPgK46iuVNAK01YN7RueYBqqFeGsBjV9XmCAzAdgt+667bCl5kPh9EqKKDwnaPG1I7A== + +normalize-url@^8.0.0: + version "8.0.0" + resolved "https://registry.yarnpkg.com/normalize-url/-/normalize-url-8.0.0.tgz#593dbd284f743e8dcf6a5ddf8fadff149c82701a" + integrity sha512-uVFpKhj5MheNBJRTiMZ9pE/7hD1QTeEvugSJW/OmLzAp78PB5O6adfMNTvmfKhXBkvCzC+rqifWcVYpGFwTjnw== + +npm-run-path@^4.0.1: + version "4.0.1" + resolved "https://registry.yarnpkg.com/npm-run-path/-/npm-run-path-4.0.1.tgz#b7ecd1e5ed53da8e37a55e1c2269e0b97ed748ea" + integrity sha512-S48WzZW777zhNIrn7gxOlISNAqi9ZC/uQFnRdbeIHhZhCA6UqpkOT8T1G7BvfdgP4Er8gF4sUbaS0i7QvIfCWw== + dependencies: + path-key "^3.0.0" + +nprogress@^0.2.0: + version "0.2.0" + resolved "https://registry.yarnpkg.com/nprogress/-/nprogress-0.2.0.tgz#cb8f34c53213d895723fcbab907e9422adbcafb1" + integrity sha512-I19aIingLgR1fmhftnbWWO3dXc0hSxqHQHQb3H8m+K3TnEn/iSeTZZOyvKXWqQESMwuUVnatlCnZdLBZZt2VSA== + +nth-check@^2.0.1: + version "2.1.1" + resolved "https://registry.yarnpkg.com/nth-check/-/nth-check-2.1.1.tgz#c9eab428effce36cd6b92c924bdb000ef1f1ed1d" + integrity sha512-lqjrjmaOoAnWfMmBPL+XNnynZh2+swxiX3WUE0s4yEHI6m+AwrK2UZOimIRl3X/4QctVqS8AiZjFqyOGrMXb/w== + dependencies: + boolbase "^1.0.0" + +object-assign@^4.1.0, object-assign@^4.1.1: + version "4.1.1" + resolved "https://registry.yarnpkg.com/object-assign/-/object-assign-4.1.1.tgz#2109adc7965887cfc05cbbd442cac8bfbb360863" + integrity sha512-rJgTQnkUnH1sFw8yT6VSU3zD3sWmu6sZhIseY8VX+GRu3P6F7Fu+JNDoXfklElbLJSnc3FUQHVe4cU5hj+BcUg== + +object-inspect@^1.9.0: + version "1.13.1" + resolved "https://registry.yarnpkg.com/object-inspect/-/object-inspect-1.13.1.tgz#b96c6109324ccfef6b12216a956ca4dc2ff94bc2" + integrity sha512-5qoj1RUiKOMsCCNLV1CBiPYE10sziTsnmNxkAI/rZhiD63CF7IqdFGC/XzjWjpSgLf0LxXX3bDFIh0E18f6UhQ== + +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.0: + version "4.1.4" + resolved "https://registry.yarnpkg.com/object.assign/-/object.assign-4.1.4.tgz#9673c7c7c351ab8c4d0b516f4343ebf4dfb7799f" + integrity sha512-1mxKf0e58bvyjSCtKYY4sRe9itRk3PJpquJOjeIkz885CczcI4IvJJDLPS72oowuSh+pBxUFROpX+TU++hxhZQ== + dependencies: + call-bind "^1.0.2" + define-properties "^1.1.4" + has-symbols "^1.0.3" + object-keys "^1.1.1" + +obuf@^1.0.0, obuf@^1.1.2: + version "1.1.2" + resolved "https://registry.yarnpkg.com/obuf/-/obuf-1.1.2.tgz#09bea3343d41859ebd446292d11c9d4db619084e" + integrity sha512-PX1wu0AmAdPqOL1mWhqmlOd8kOIZQwGZw6rh7uby9fTc5lhaOWFLX3I6R1hrF9k3zUY40e6igsLGkDXK92LJNg== + +on-finished@2.4.1: + version "2.4.1" + resolved "https://registry.yarnpkg.com/on-finished/-/on-finished-2.4.1.tgz#58c8c44116e54845ad57f14ab10b03533184ac3f" + integrity sha512-oVlzkg3ENAhCk2zdv7IJwd/QUD4z2RxRwpkcGY8psCVcCYZNq4wYnVWALHM+brtuJjePWiYF/ClmuDr8Ch5+kg== + dependencies: + ee-first "1.1.1" + +on-headers@~1.0.2: + version "1.0.2" + resolved "https://registry.yarnpkg.com/on-headers/-/on-headers-1.0.2.tgz#772b0ae6aaa525c399e489adfad90c403eb3c28f" + integrity sha512-pZAE+FJLoyITytdqK0U5s+FIpjN0JP3OzFi/u8Rx+EV5/W+JTWGXG8xFzevE7AjBfDqHv/8vL8qQsIhHnqRkrA== + +once@^1.3.0: + version "1.4.0" + resolved "https://registry.yarnpkg.com/once/-/once-1.4.0.tgz#583b1aa775961d4b113ac17d9c50baef9dd76bd1" + integrity sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w== + dependencies: + wrappy "1" + +onetime@^5.1.2: + version "5.1.2" + resolved "https://registry.yarnpkg.com/onetime/-/onetime-5.1.2.tgz#d0e96ebb56b07476df1dd9c4806e5237985ca45e" + integrity sha512-kbpaSSGJTWdAY5KPVeMOKXSrPtr8C8C7wodJbcsd51jRnmD+GZu8Y0VoU6Dm5Z4vWr0Ig/1NKuWRKf7j5aaYSg== + dependencies: + mimic-fn "^2.1.0" + +open@^8.0.9, open@^8.4.0: + version "8.4.2" + resolved "https://registry.yarnpkg.com/open/-/open-8.4.2.tgz#5b5ffe2a8f793dcd2aad73e550cb87b59cb084f9" + integrity sha512-7x81NCL719oNbsq/3mh+hVrAWmFuEYUqrq/Iw3kUzH8ReypT9QQ0BLoJS7/G9k6N81XjW4qHWtjWwe/9eLy1EQ== + dependencies: + define-lazy-prop "^2.0.0" + is-docker "^2.1.1" + is-wsl "^2.2.0" + +opener@^1.5.2: + version "1.5.2" + resolved "https://registry.yarnpkg.com/opener/-/opener-1.5.2.tgz#5d37e1f35077b9dcac4301372271afdeb2a13598" + integrity sha512-ur5UIdyw5Y7yEj9wLzhqXiy6GZ3Mwx0yGI+5sMn2r0N0v3cKJvUmFH5yPP+WXh9e0xfyzyJX95D8l088DNFj7A== + +p-cancelable@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/p-cancelable/-/p-cancelable-3.0.0.tgz#63826694b54d61ca1c20ebcb6d3ecf5e14cd8050" + integrity sha512-mlVgR3PGuzlo0MmTdk4cXqXWlwQDLnONTAg6sm62XkMJEiRxN3GL3SffkYvqwonbkJBcrI7Uvv5Zh9yjvn2iUw== + +p-limit@^2.0.0: + version "2.3.0" + resolved "https://registry.yarnpkg.com/p-limit/-/p-limit-2.3.0.tgz#3dd33c647a214fdfffd835933eb086da0dc21db1" + integrity sha512-//88mFWSJx8lxCzwdAABTJL2MyWB12+eIY7MDL2SqLmAkeKU9qxRvWuSyTjm3FUmpBEMuFfckAIqEaVGUDxb6w== + dependencies: + p-try "^2.0.0" + +p-limit@^3.0.2: + version "3.1.0" + resolved "https://registry.yarnpkg.com/p-limit/-/p-limit-3.1.0.tgz#e1daccbe78d0d1388ca18c64fea38e3e57e3706b" + integrity sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ== + dependencies: + yocto-queue "^0.1.0" + +p-limit@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/p-limit/-/p-limit-4.0.0.tgz#914af6544ed32bfa54670b061cafcbd04984b644" + integrity sha512-5b0R4txpzjPWVw/cXXUResoD4hb6U/x9BH08L7nw+GN1sezDzPdxeRvpc9c433fZhBan/wusjbCsqwqm4EIBIQ== + dependencies: + yocto-queue "^1.0.0" + +p-locate@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/p-locate/-/p-locate-3.0.0.tgz#322d69a05c0264b25997d9f40cd8a891ab0064a4" + integrity sha512-x+12w/To+4GFfgJhBEpiDcLozRJGegY+Ei7/z0tSLkMmxGZNybVMSfWj9aJn8Z5Fc7dBUNJOOVgPv2H7IwulSQ== + dependencies: + p-limit "^2.0.0" + +p-locate@^5.0.0: + version "5.0.0" + resolved "https://registry.yarnpkg.com/p-locate/-/p-locate-5.0.0.tgz#83c8315c6785005e3bd021839411c9e110e6d834" + integrity sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw== + dependencies: + p-limit "^3.0.2" + +p-locate@^6.0.0: + version "6.0.0" + resolved "https://registry.yarnpkg.com/p-locate/-/p-locate-6.0.0.tgz#3da9a49d4934b901089dca3302fa65dc5a05c04f" + integrity sha512-wPrq66Llhl7/4AGC6I+cqxT07LhXvWL08LNXz1fENOw0Ap4sRZZ/gZpTTJ5jpurzzzfS2W/Ge9BY3LgLjCShcw== + dependencies: + p-limit "^4.0.0" + +p-map@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/p-map/-/p-map-4.0.0.tgz#bb2f95a5eda2ec168ec9274e06a747c3e2904d2b" + integrity sha512-/bjOqmgETBYB5BoEeGVea8dmvHb2m9GLy1E9W43yeyfP6QQCZGFNa+XRceJEuDB6zqr+gKpIAmlLebMpykw/MQ== + dependencies: + aggregate-error "^3.0.0" + +p-retry@^4.5.0: + version "4.6.2" + resolved "https://registry.yarnpkg.com/p-retry/-/p-retry-4.6.2.tgz#9baae7184057edd4e17231cee04264106e092a16" + integrity sha512-312Id396EbJdvRONlngUx0NydfrIQ5lsYu0znKVUzVvArzEIt08V1qhtyESbGVd1FGX7UKtiFp5uwKZdM8wIuQ== + dependencies: + "@types/retry" "0.12.0" + retry "^0.13.1" + +p-try@^2.0.0: + version "2.2.0" + resolved "https://registry.yarnpkg.com/p-try/-/p-try-2.2.0.tgz#cb2868540e313d61de58fafbe35ce9004d5540e6" + integrity sha512-R4nPAVTAU0B9D35/Gk3uJf/7XYbQcyohSKdvAxIRSNghFl4e71hVoGnBNQz9cWaXxO2I10KTC+3jMdvvoKw6dQ== + +package-json@^8.1.0: + version "8.1.1" + resolved "https://registry.yarnpkg.com/package-json/-/package-json-8.1.1.tgz#3e9948e43df40d1e8e78a85485f1070bf8f03dc8" + integrity sha512-cbH9IAIJHNj9uXi196JVsRlt7cHKak6u/e6AkL/bkRelZ7rlL3X1YKxsZwa36xipOEKAsdtmaG6aAJoM1fx2zA== + dependencies: + got "^12.1.0" + registry-auth-token "^5.0.1" + registry-url "^6.0.0" + semver "^7.3.7" + +param-case@^3.0.4: + version "3.0.4" + resolved "https://registry.yarnpkg.com/param-case/-/param-case-3.0.4.tgz#7d17fe4aa12bde34d4a77d91acfb6219caad01c5" + integrity sha512-RXlj7zCYokReqWpOPH9oYivUzLYZ5vAPIfEmCTNViosC78F8F0H9y7T7gG2M39ymgutxF5gcFEsyZQSph9Bp3A== + dependencies: + dot-case "^3.0.4" + tslib "^2.0.3" + +parent-module@^1.0.0: + version "1.0.1" + resolved "https://registry.yarnpkg.com/parent-module/-/parent-module-1.0.1.tgz#691d2709e78c79fae3a156622452d00762caaaa2" + integrity sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g== + dependencies: + callsites "^3.0.0" + +parse-entities@^4.0.0: + version "4.0.1" + resolved "https://registry.yarnpkg.com/parse-entities/-/parse-entities-4.0.1.tgz#4e2a01111fb1c986549b944af39eeda258fc9e4e" + integrity sha512-SWzvYcSJh4d/SGLIOQfZ/CoNv6BTlI6YEQ7Nj82oDVnRpwe/Z/F1EMx42x3JAOwGBlCjeCH0BRJQbQ/opHL17w== + dependencies: + "@types/unist" "^2.0.0" + character-entities "^2.0.0" + character-entities-legacy "^3.0.0" + character-reference-invalid "^2.0.0" + decode-named-character-reference "^1.0.0" + is-alphanumerical "^2.0.0" + is-decimal "^2.0.0" + is-hexadecimal "^2.0.0" + +parse-json@^5.0.0, parse-json@^5.2.0: + version "5.2.0" + resolved "https://registry.yarnpkg.com/parse-json/-/parse-json-5.2.0.tgz#c76fc66dee54231c962b22bcc8a72cf2f99753cd" + integrity sha512-ayCKvm/phCGxOkYRSCM82iDwct8/EonSEgCSxWxD7ve6jHggsFl4fZVQBPRNgQoKiuV/odhFrGzQXZwbifC8Rg== + dependencies: + "@babel/code-frame" "^7.0.0" + error-ex "^1.3.1" + json-parse-even-better-errors "^2.3.0" + lines-and-columns "^1.1.6" + +parse-numeric-range@^1.3.0: + version "1.3.0" + resolved "https://registry.yarnpkg.com/parse-numeric-range/-/parse-numeric-range-1.3.0.tgz#7c63b61190d61e4d53a1197f0c83c47bb670ffa3" + integrity sha512-twN+njEipszzlMJd4ONUYgSfZPDxgHhT9Ahed5uTigpQn90FggW4SA/AIPq/6a149fTbE9qBEcSwE3FAEp6wQQ== + +parse5-htmlparser2-tree-adapter@^7.0.0: + version "7.0.0" + resolved "https://registry.yarnpkg.com/parse5-htmlparser2-tree-adapter/-/parse5-htmlparser2-tree-adapter-7.0.0.tgz#23c2cc233bcf09bb7beba8b8a69d46b08c62c2f1" + integrity sha512-B77tOZrqqfUfnVcOrUvfdLbz4pu4RopLD/4vmu3HUPswwTA8OH0EMW9BlWR2B0RCoiZRAHEUu7IxeP1Pd1UU+g== + dependencies: + domhandler "^5.0.2" + parse5 "^7.0.0" + +parse5@^7.0.0: + version "7.1.2" + resolved "https://registry.yarnpkg.com/parse5/-/parse5-7.1.2.tgz#0736bebbfd77793823240a23b7fc5e010b7f8e32" + integrity sha512-Czj1WaSVpaoj0wbhMzLmWD69anp2WH7FXMB9n1Sy8/ZFF9jolSQVMu1Ij5WIyGmcBmhk7EOndpO4mIpihVqAXw== + dependencies: + entities "^4.4.0" + +parseurl@~1.3.2, parseurl@~1.3.3: + version "1.3.3" + resolved "https://registry.yarnpkg.com/parseurl/-/parseurl-1.3.3.tgz#9da19e7bee8d12dff0513ed5b76957793bc2e8d4" + integrity sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ== + +pascal-case@^3.1.2: + version "3.1.2" + resolved "https://registry.yarnpkg.com/pascal-case/-/pascal-case-3.1.2.tgz#b48e0ef2b98e205e7c1dae747d0b1508237660eb" + integrity sha512-uWlGT3YSnK9x3BQJaOdcZwrnV6hPpd8jFH1/ucpiLRPh/2zCVJKS19E4GvYHvaCcACn3foXZ0cLB9Wrx1KGe5g== + dependencies: + no-case "^3.0.4" + tslib "^2.0.3" + +path-exists@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/path-exists/-/path-exists-3.0.0.tgz#ce0ebeaa5f78cb18925ea7d810d7b59b010fd515" + integrity sha512-bpC7GYwiDYQ4wYLe+FA8lhRjhQCMcQGuSgGGqDkg/QerRWw9CmGRT0iSOVRSZJ29NMLZgIzqaljJ63oaL4NIJQ== + +path-exists@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/path-exists/-/path-exists-4.0.0.tgz#513bdbe2d3b95d7762e8c1137efa195c6c61b5b3" + integrity sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w== + +path-exists@^5.0.0: + version "5.0.0" + resolved "https://registry.yarnpkg.com/path-exists/-/path-exists-5.0.0.tgz#a6aad9489200b21fab31e49cf09277e5116fb9e7" + integrity sha512-RjhtfwJOxzcFmNOi6ltcbcu4Iu+FL3zEj83dk4kAS+fVpTxXLO1b38RvJgT/0QwvV/L3aY9TAnyv0EOqW4GoMQ== + +path-is-absolute@^1.0.0: + version "1.0.1" + resolved "https://registry.yarnpkg.com/path-is-absolute/-/path-is-absolute-1.0.1.tgz#174b9268735534ffbc7ace6bf53a5a9e1b5c5f5f" + integrity sha512-AVbw3UJ2e9bq64vSaS9Am0fje1Pa8pbGqTTsmXfaIiMpnr5DlDhfJOuLj9Sf95ZPVDAUerDfEk88MPmPe7UCQg== + +path-is-inside@1.0.2: + version "1.0.2" + resolved "https://registry.yarnpkg.com/path-is-inside/-/path-is-inside-1.0.2.tgz#365417dede44430d1c11af61027facf074bdfc53" + integrity sha512-DUWJr3+ULp4zXmol/SZkFf3JGsS9/SIv+Y3Rt93/UjPpDpklB5f1er4O3POIbUuUJ3FXgqte2Q7SrU6zAqwk8w== + +path-key@^3.0.0, path-key@^3.1.0: + version "3.1.1" + resolved "https://registry.yarnpkg.com/path-key/-/path-key-3.1.1.tgz#581f6ade658cbba65a0d3380de7753295054f375" + integrity sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q== + +path-parse@^1.0.7: + version "1.0.7" + resolved "https://registry.yarnpkg.com/path-parse/-/path-parse-1.0.7.tgz#fbc114b60ca42b30d9daf5858e4bd68bbedb6735" + integrity sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw== + +path-to-regexp@0.1.7: + version "0.1.7" + resolved "https://registry.yarnpkg.com/path-to-regexp/-/path-to-regexp-0.1.7.tgz#df604178005f522f15eb4490e7247a1bfaa67f8c" + integrity sha512-5DFkuoqlv1uYQKxy8omFBeJPQcdoE07Kv2sferDCrAq1ohOU+MSDswDIbnx3YAM60qIOnYa53wBhXW0EbMonrQ== + +path-to-regexp@2.2.1: + version "2.2.1" + resolved "https://registry.yarnpkg.com/path-to-regexp/-/path-to-regexp-2.2.1.tgz#90b617025a16381a879bc82a38d4e8bdeb2bcf45" + integrity sha512-gu9bD6Ta5bwGrrU8muHzVOBFFREpp2iRkVfhBJahwJ6p6Xw20SjT0MxLnwkjOibQmGSYhiUnf2FLe7k+jcFmGQ== + +path-to-regexp@^1.7.0: + version "1.8.0" + resolved "https://registry.yarnpkg.com/path-to-regexp/-/path-to-regexp-1.8.0.tgz#887b3ba9d84393e87a0a0b9f4cb756198b53548a" + integrity sha512-n43JRhlUKUAlibEJhPeir1ncUID16QnEjNpwzNdO3Lm4ywrBpBZ5oLD0I6br9evr1Y9JTqwRtAh7JLoOzAQdVA== + dependencies: + isarray "0.0.1" + +path-type@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/path-type/-/path-type-4.0.0.tgz#84ed01c0a7ba380afe09d90a8c180dcd9d03043b" + integrity sha512-gDKb8aZMDeD/tZWs9P6+q0J9Mwkdl6xMV8TjnGP3qJVJ06bdMgkbBlLU8IdfOsIsFz2BW1rNVT3XuNEl8zPAvw== + +periscopic@^3.0.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" + +picocolors@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/picocolors/-/picocolors-1.0.0.tgz#cb5bdc74ff3f51892236eaf79d68bc44564ab81c" + integrity sha512-1fygroTLlHu66zi26VoTDv8yRgm0Fccecssto+MhsZ0D/DGW2sm8E8AjW7NU5VVTRt5GxbeZ5qBuJr+HyLYkjQ== + +picomatch@^2.0.4, picomatch@^2.2.1, picomatch@^2.2.3, picomatch@^2.3.1: + version "2.3.1" + resolved "https://registry.yarnpkg.com/picomatch/-/picomatch-2.3.1.tgz#3ba3833733646d9d3e4995946c1365a67fb07a42" + integrity sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA== + +pkg-dir@^7.0.0: + version "7.0.0" + resolved "https://registry.yarnpkg.com/pkg-dir/-/pkg-dir-7.0.0.tgz#8f0c08d6df4476756c5ff29b3282d0bab7517d11" + integrity sha512-Ie9z/WINcxxLp27BKOCHGde4ITq9UklYKDzVo1nhk5sqGEXU3FpkwP5GM2voTGJkGd9B3Otl+Q4uwSOeSUtOBA== + dependencies: + find-up "^6.3.0" + +pkg-up@^3.1.0: + version "3.1.0" + resolved "https://registry.yarnpkg.com/pkg-up/-/pkg-up-3.1.0.tgz#100ec235cc150e4fd42519412596a28512a0def5" + integrity sha512-nDywThFk1i4BQK4twPQ6TA4RT8bDY96yeuCVBWL3ePARCiEKDRSrNGbFIgUJpLp+XeIR65v8ra7WuJOFUBtkMA== + dependencies: + find-up "^3.0.0" + +postcss-calc@^8.2.3: + version "8.2.4" + resolved "https://registry.yarnpkg.com/postcss-calc/-/postcss-calc-8.2.4.tgz#77b9c29bfcbe8a07ff6693dc87050828889739a5" + integrity sha512-SmWMSJmB8MRnnULldx0lQIyhSNvuDl9HfrZkaqqE/WHAhToYsAvDq+yAsA/kIyINDszOp3Rh0GFoNuH5Ypsm3Q== + dependencies: + postcss-selector-parser "^6.0.9" + postcss-value-parser "^4.2.0" + +postcss-colormin@^5.3.1: + version "5.3.1" + resolved "https://registry.yarnpkg.com/postcss-colormin/-/postcss-colormin-5.3.1.tgz#86c27c26ed6ba00d96c79e08f3ffb418d1d1988f" + integrity sha512-UsWQG0AqTFQmpBegeLLc1+c3jIqBNB0zlDGRWR+dQ3pRKJL1oeMzyqmH3o2PIfn9MBdNrVPWhDbT769LxCTLJQ== + dependencies: + browserslist "^4.21.4" + caniuse-api "^3.0.0" + colord "^2.9.1" + postcss-value-parser "^4.2.0" + +postcss-convert-values@^5.1.3: + version "5.1.3" + resolved "https://registry.yarnpkg.com/postcss-convert-values/-/postcss-convert-values-5.1.3.tgz#04998bb9ba6b65aa31035d669a6af342c5f9d393" + integrity sha512-82pC1xkJZtcJEfiLw6UXnXVXScgtBrjlO5CBmuDQc+dlb88ZYheFsjTn40+zBVi3DkfF7iezO0nJUPLcJK3pvA== + dependencies: + browserslist "^4.21.4" + postcss-value-parser "^4.2.0" + +postcss-discard-comments@^5.1.2: + version "5.1.2" + resolved "https://registry.yarnpkg.com/postcss-discard-comments/-/postcss-discard-comments-5.1.2.tgz#8df5e81d2925af2780075840c1526f0660e53696" + integrity sha512-+L8208OVbHVF2UQf1iDmRcbdjJkuBF6IS29yBDSiWUIzpYaAhtNl6JYnYm12FnkeCwQqF5LeklOu6rAqgfBZqQ== + +postcss-discard-duplicates@^5.1.0: + version "5.1.0" + resolved "https://registry.yarnpkg.com/postcss-discard-duplicates/-/postcss-discard-duplicates-5.1.0.tgz#9eb4fe8456706a4eebd6d3b7b777d07bad03e848" + integrity sha512-zmX3IoSI2aoenxHV6C7plngHWWhUOV3sP1T8y2ifzxzbtnuhk1EdPwm0S1bIUNaJ2eNbWeGLEwzw8huPD67aQw== + +postcss-discard-empty@^5.1.1: + version "5.1.1" + resolved "https://registry.yarnpkg.com/postcss-discard-empty/-/postcss-discard-empty-5.1.1.tgz#e57762343ff7f503fe53fca553d18d7f0c369c6c" + integrity sha512-zPz4WljiSuLWsI0ir4Mcnr4qQQ5e1Ukc3i7UfE2XcrwKK2LIPIqE5jxMRxO6GbI3cv//ztXDsXwEWT3BHOGh3A== + +postcss-discard-overridden@^5.1.0: + version "5.1.0" + resolved "https://registry.yarnpkg.com/postcss-discard-overridden/-/postcss-discard-overridden-5.1.0.tgz#7e8c5b53325747e9d90131bb88635282fb4a276e" + integrity sha512-21nOL7RqWR1kasIVdKs8HNqQJhFxLsyRfAnUDm4Fe4t4mCWL9OJiHvlHPjcd8zc5Myu89b/7wZDnOSjFgeWRtw== + +postcss-discard-unused@^5.1.0: + version "5.1.0" + resolved "https://registry.yarnpkg.com/postcss-discard-unused/-/postcss-discard-unused-5.1.0.tgz#8974e9b143d887677304e558c1166d3762501142" + integrity sha512-KwLWymI9hbwXmJa0dkrzpRbSJEh0vVUd7r8t0yOGPcfKzyJJxFM8kLyC5Ev9avji6nY95pOp1W6HqIrfT+0VGw== + dependencies: + postcss-selector-parser "^6.0.5" + +postcss-loader@^7.3.3: + version "7.3.3" + resolved "https://registry.yarnpkg.com/postcss-loader/-/postcss-loader-7.3.3.tgz#6da03e71a918ef49df1bb4be4c80401df8e249dd" + integrity sha512-YgO/yhtevGO/vJePCQmTxiaEwER94LABZN0ZMT4A0vsak9TpO+RvKRs7EmJ8peIlB9xfXCsS7M8LjqncsUZ5HA== + dependencies: + cosmiconfig "^8.2.0" + jiti "^1.18.2" + semver "^7.3.8" + +postcss-merge-idents@^5.1.1: + version "5.1.1" + resolved "https://registry.yarnpkg.com/postcss-merge-idents/-/postcss-merge-idents-5.1.1.tgz#7753817c2e0b75d0853b56f78a89771e15ca04a1" + integrity sha512-pCijL1TREiCoog5nQp7wUe+TUonA2tC2sQ54UGeMmryK3UFGIYKqDyjnqd6RcuI4znFn9hWSLNN8xKE/vWcUQw== + dependencies: + cssnano-utils "^3.1.0" + postcss-value-parser "^4.2.0" + +postcss-merge-longhand@^5.1.7: + version "5.1.7" + resolved "https://registry.yarnpkg.com/postcss-merge-longhand/-/postcss-merge-longhand-5.1.7.tgz#24a1bdf402d9ef0e70f568f39bdc0344d568fb16" + integrity sha512-YCI9gZB+PLNskrK0BB3/2OzPnGhPkBEwmwhfYk1ilBHYVAZB7/tkTHFBAnCrvBBOmeYyMYw3DMjT55SyxMBzjQ== + dependencies: + postcss-value-parser "^4.2.0" + stylehacks "^5.1.1" + +postcss-merge-rules@^5.1.4: + version "5.1.4" + resolved "https://registry.yarnpkg.com/postcss-merge-rules/-/postcss-merge-rules-5.1.4.tgz#2f26fa5cacb75b1402e213789f6766ae5e40313c" + integrity sha512-0R2IuYpgU93y9lhVbO/OylTtKMVcHb67zjWIfCiKR9rWL3GUk1677LAqD/BcHizukdZEjT8Ru3oHRoAYoJy44g== + dependencies: + browserslist "^4.21.4" + caniuse-api "^3.0.0" + cssnano-utils "^3.1.0" + postcss-selector-parser "^6.0.5" + +postcss-minify-font-values@^5.1.0: + version "5.1.0" + resolved "https://registry.yarnpkg.com/postcss-minify-font-values/-/postcss-minify-font-values-5.1.0.tgz#f1df0014a726083d260d3bd85d7385fb89d1f01b" + integrity sha512-el3mYTgx13ZAPPirSVsHqFzl+BBBDrXvbySvPGFnQcTI4iNslrPaFq4muTkLZmKlGk4gyFAYUBMH30+HurREyA== + dependencies: + postcss-value-parser "^4.2.0" + +postcss-minify-gradients@^5.1.1: + version "5.1.1" + resolved "https://registry.yarnpkg.com/postcss-minify-gradients/-/postcss-minify-gradients-5.1.1.tgz#f1fe1b4f498134a5068240c2f25d46fcd236ba2c" + integrity sha512-VGvXMTpCEo4qHTNSa9A0a3D+dxGFZCYwR6Jokk+/3oB6flu2/PnPXAh2x7x52EkY5xlIHLm+Le8tJxe/7TNhzw== + dependencies: + colord "^2.9.1" + cssnano-utils "^3.1.0" + postcss-value-parser "^4.2.0" + +postcss-minify-params@^5.1.4: + version "5.1.4" + resolved "https://registry.yarnpkg.com/postcss-minify-params/-/postcss-minify-params-5.1.4.tgz#c06a6c787128b3208b38c9364cfc40c8aa5d7352" + integrity sha512-+mePA3MgdmVmv6g+30rn57USjOGSAyuxUmkfiWpzalZ8aiBkdPYjXWtHuwJGm1v5Ojy0Z0LaSYhHaLJQB0P8Jw== + dependencies: + browserslist "^4.21.4" + cssnano-utils "^3.1.0" + postcss-value-parser "^4.2.0" + +postcss-minify-selectors@^5.2.1: + version "5.2.1" + resolved "https://registry.yarnpkg.com/postcss-minify-selectors/-/postcss-minify-selectors-5.2.1.tgz#d4e7e6b46147b8117ea9325a915a801d5fe656c6" + integrity sha512-nPJu7OjZJTsVUmPdm2TcaiohIwxP+v8ha9NehQ2ye9szv4orirRU3SDdtUmKH+10nzn0bAyOXZ0UEr7OpvLehg== + dependencies: + postcss-selector-parser "^6.0.5" + +postcss-modules-extract-imports@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/postcss-modules-extract-imports/-/postcss-modules-extract-imports-3.0.0.tgz#cda1f047c0ae80c97dbe28c3e76a43b88025741d" + integrity sha512-bdHleFnP3kZ4NYDhuGlVK+CMrQ/pqUm8bx/oGL93K6gVwiclvX5x0n76fYMKuIGKzlABOy13zsvqjb0f92TEXw== + +postcss-modules-local-by-default@^4.0.3: + version "4.0.3" + resolved "https://registry.yarnpkg.com/postcss-modules-local-by-default/-/postcss-modules-local-by-default-4.0.3.tgz#b08eb4f083050708998ba2c6061b50c2870ca524" + integrity sha512-2/u2zraspoACtrbFRnTijMiQtb4GW4BvatjaG/bCjYQo8kLTdevCUlwuBHx2sCnSyrI3x3qj4ZK1j5LQBgzmwA== + dependencies: + icss-utils "^5.0.0" + postcss-selector-parser "^6.0.2" + postcss-value-parser "^4.1.0" + +postcss-modules-scope@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/postcss-modules-scope/-/postcss-modules-scope-3.0.0.tgz#9ef3151456d3bbfa120ca44898dfca6f2fa01f06" + integrity sha512-hncihwFA2yPath8oZ15PZqvWGkWf+XUfQgUGamS4LqoP1anQLOsOJw0vr7J7IwLpoY9fatA2qiGUGmuZL0Iqlg== + dependencies: + postcss-selector-parser "^6.0.4" + +postcss-modules-values@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/postcss-modules-values/-/postcss-modules-values-4.0.0.tgz#d7c5e7e68c3bb3c9b27cbf48ca0bb3ffb4602c9c" + integrity sha512-RDxHkAiEGI78gS2ofyvCsu7iycRv7oqw5xMWn9iMoR0N/7mf9D50ecQqUo5BZ9Zh2vH4bCUR/ktCqbB9m8vJjQ== + dependencies: + icss-utils "^5.0.0" + +postcss-normalize-charset@^5.1.0: + version "5.1.0" + resolved "https://registry.yarnpkg.com/postcss-normalize-charset/-/postcss-normalize-charset-5.1.0.tgz#9302de0b29094b52c259e9b2cf8dc0879879f0ed" + integrity sha512-mSgUJ+pd/ldRGVx26p2wz9dNZ7ji6Pn8VWBajMXFf8jk7vUoSrZ2lt/wZR7DtlZYKesmZI680qjr2CeFF2fbUg== + +postcss-normalize-display-values@^5.1.0: + version "5.1.0" + resolved "https://registry.yarnpkg.com/postcss-normalize-display-values/-/postcss-normalize-display-values-5.1.0.tgz#72abbae58081960e9edd7200fcf21ab8325c3da8" + integrity sha512-WP4KIM4o2dazQXWmFaqMmcvsKmhdINFblgSeRgn8BJ6vxaMyaJkwAzpPpuvSIoG/rmX3M+IrRZEz2H0glrQNEA== + dependencies: + postcss-value-parser "^4.2.0" + +postcss-normalize-positions@^5.1.1: + version "5.1.1" + resolved "https://registry.yarnpkg.com/postcss-normalize-positions/-/postcss-normalize-positions-5.1.1.tgz#ef97279d894087b59325b45c47f1e863daefbb92" + integrity sha512-6UpCb0G4eofTCQLFVuI3EVNZzBNPiIKcA1AKVka+31fTVySphr3VUgAIULBhxZkKgwLImhzMR2Bw1ORK+37INg== + dependencies: + postcss-value-parser "^4.2.0" + +postcss-normalize-repeat-style@^5.1.1: + version "5.1.1" + resolved "https://registry.yarnpkg.com/postcss-normalize-repeat-style/-/postcss-normalize-repeat-style-5.1.1.tgz#e9eb96805204f4766df66fd09ed2e13545420fb2" + integrity sha512-mFpLspGWkQtBcWIRFLmewo8aC3ImN2i/J3v8YCFUwDnPu3Xz4rLohDO26lGjwNsQxB3YF0KKRwspGzE2JEuS0g== + dependencies: + postcss-value-parser "^4.2.0" + +postcss-normalize-string@^5.1.0: + version "5.1.0" + resolved "https://registry.yarnpkg.com/postcss-normalize-string/-/postcss-normalize-string-5.1.0.tgz#411961169e07308c82c1f8c55f3e8a337757e228" + integrity sha512-oYiIJOf4T9T1N4i+abeIc7Vgm/xPCGih4bZz5Nm0/ARVJ7K6xrDlLwvwqOydvyL3RHNf8qZk6vo3aatiw/go3w== + dependencies: + postcss-value-parser "^4.2.0" + +postcss-normalize-timing-functions@^5.1.0: + version "5.1.0" + resolved "https://registry.yarnpkg.com/postcss-normalize-timing-functions/-/postcss-normalize-timing-functions-5.1.0.tgz#d5614410f8f0b2388e9f240aa6011ba6f52dafbb" + integrity sha512-DOEkzJ4SAXv5xkHl0Wa9cZLF3WCBhF3o1SKVxKQAa+0pYKlueTpCgvkFAHfk+Y64ezX9+nITGrDZeVGgITJXjg== + dependencies: + postcss-value-parser "^4.2.0" + +postcss-normalize-unicode@^5.1.1: + version "5.1.1" + resolved "https://registry.yarnpkg.com/postcss-normalize-unicode/-/postcss-normalize-unicode-5.1.1.tgz#f67297fca3fea7f17e0d2caa40769afc487aa030" + integrity sha512-qnCL5jzkNUmKVhZoENp1mJiGNPcsJCs1aaRmURmeJGES23Z/ajaln+EPTD+rBeNkSryI+2WTdW+lwcVdOikrpA== + dependencies: + browserslist "^4.21.4" + postcss-value-parser "^4.2.0" + +postcss-normalize-url@^5.1.0: + version "5.1.0" + resolved "https://registry.yarnpkg.com/postcss-normalize-url/-/postcss-normalize-url-5.1.0.tgz#ed9d88ca82e21abef99f743457d3729a042adcdc" + integrity sha512-5upGeDO+PVthOxSmds43ZeMeZfKH+/DKgGRD7TElkkyS46JXAUhMzIKiCa7BabPeIy3AQcTkXwVVN7DbqsiCew== + dependencies: + normalize-url "^6.0.1" + postcss-value-parser "^4.2.0" + +postcss-normalize-whitespace@^5.1.1: + version "5.1.1" + resolved "https://registry.yarnpkg.com/postcss-normalize-whitespace/-/postcss-normalize-whitespace-5.1.1.tgz#08a1a0d1ffa17a7cc6efe1e6c9da969cc4493cfa" + integrity sha512-83ZJ4t3NUDETIHTa3uEg6asWjSBYL5EdkVB0sDncx9ERzOKBVJIUeDO9RyA9Zwtig8El1d79HBp0JEi8wvGQnA== + dependencies: + postcss-value-parser "^4.2.0" + +postcss-ordered-values@^5.1.3: + version "5.1.3" + resolved "https://registry.yarnpkg.com/postcss-ordered-values/-/postcss-ordered-values-5.1.3.tgz#b6fd2bd10f937b23d86bc829c69e7732ce76ea38" + integrity sha512-9UO79VUhPwEkzbb3RNpqqghc6lcYej1aveQteWY+4POIwlqkYE21HKWaLDF6lWNuqCobEAyTovVhtI32Rbv2RQ== + dependencies: + cssnano-utils "^3.1.0" + postcss-value-parser "^4.2.0" + +postcss-reduce-idents@^5.2.0: + version "5.2.0" + resolved "https://registry.yarnpkg.com/postcss-reduce-idents/-/postcss-reduce-idents-5.2.0.tgz#c89c11336c432ac4b28792f24778859a67dfba95" + integrity sha512-BTrLjICoSB6gxbc58D5mdBK8OhXRDqud/zodYfdSi52qvDHdMwk+9kB9xsM8yJThH/sZU5A6QVSmMmaN001gIg== + dependencies: + postcss-value-parser "^4.2.0" + +postcss-reduce-initial@^5.1.2: + version "5.1.2" + resolved "https://registry.yarnpkg.com/postcss-reduce-initial/-/postcss-reduce-initial-5.1.2.tgz#798cd77b3e033eae7105c18c9d371d989e1382d6" + integrity sha512-dE/y2XRaqAi6OvjzD22pjTUQ8eOfc6m/natGHgKFBK9DxFmIm69YmaRVQrGgFlEfc1HePIurY0TmDeROK05rIg== + dependencies: + browserslist "^4.21.4" + caniuse-api "^3.0.0" + +postcss-reduce-transforms@^5.1.0: + version "5.1.0" + resolved "https://registry.yarnpkg.com/postcss-reduce-transforms/-/postcss-reduce-transforms-5.1.0.tgz#333b70e7758b802f3dd0ddfe98bb1ccfef96b6e9" + integrity sha512-2fbdbmgir5AvpW9RLtdONx1QoYG2/EtqpNQbFASDlixBbAYuTcJ0dECwlqNqH7VbaUnEnh8SrxOe2sRIn24XyQ== + dependencies: + postcss-value-parser "^4.2.0" + +postcss-selector-parser@^6.0.2, postcss-selector-parser@^6.0.4, postcss-selector-parser@^6.0.5, postcss-selector-parser@^6.0.9: + version "6.0.13" + resolved "https://registry.yarnpkg.com/postcss-selector-parser/-/postcss-selector-parser-6.0.13.tgz#d05d8d76b1e8e173257ef9d60b706a8e5e99bf1b" + integrity sha512-EaV1Gl4mUEV4ddhDnv/xtj7sxwrwxdetHdWUGnT4VJQf+4d05v6lHYZr8N573k5Z0BViss7BDhfWtKS3+sfAqQ== + dependencies: + cssesc "^3.0.0" + util-deprecate "^1.0.2" + +postcss-sort-media-queries@^4.4.1: + version "4.4.1" + resolved "https://registry.yarnpkg.com/postcss-sort-media-queries/-/postcss-sort-media-queries-4.4.1.tgz#04a5a78db3921eb78f28a1a781a2e68e65258128" + integrity sha512-QDESFzDDGKgpiIh4GYXsSy6sek2yAwQx1JASl5AxBtU1Lq2JfKBljIPNdil989NcSKRQX1ToiaKphImtBuhXWw== + dependencies: + sort-css-media-queries "2.1.0" + +postcss-svgo@^5.1.0: + version "5.1.0" + resolved "https://registry.yarnpkg.com/postcss-svgo/-/postcss-svgo-5.1.0.tgz#0a317400ced789f233a28826e77523f15857d80d" + integrity sha512-D75KsH1zm5ZrHyxPakAxJWtkyXew5qwS70v56exwvw542d9CRtTo78K0WeFxZB4G7JXKKMbEZtZayTGdIky/eA== + dependencies: + postcss-value-parser "^4.2.0" + svgo "^2.7.0" + +postcss-unique-selectors@^5.1.1: + version "5.1.1" + resolved "https://registry.yarnpkg.com/postcss-unique-selectors/-/postcss-unique-selectors-5.1.1.tgz#a9f273d1eacd09e9aa6088f4b0507b18b1b541b6" + integrity sha512-5JiODlELrz8L2HwxfPnhOWZYWDxVHWL83ufOv84NrcgipI7TaeRsatAhK4Tr2/ZiYldpK/wBvw5BD3qfaK96GA== + dependencies: + postcss-selector-parser "^6.0.5" + +postcss-value-parser@^4.1.0, postcss-value-parser@^4.2.0: + version "4.2.0" + resolved "https://registry.yarnpkg.com/postcss-value-parser/-/postcss-value-parser-4.2.0.tgz#723c09920836ba6d3e5af019f92bc0971c02e514" + integrity sha512-1NNCs6uurfkVbeXG4S8JFT9t19m45ICnif8zWLd5oPSZ50QnwMfK+H3jv408d4jw/7Bttv5axS5IiHoLaVNHeQ== + +postcss-zindex@^5.1.0: + version "5.1.0" + resolved "https://registry.yarnpkg.com/postcss-zindex/-/postcss-zindex-5.1.0.tgz#4a5c7e5ff1050bd4c01d95b1847dfdcc58a496ff" + integrity sha512-fgFMf0OtVSBR1va1JNHYgMxYk73yhn/qb4uQDq1DLGYolz8gHCyr/sesEuGUaYs58E3ZJRcpoGuPVoB7Meiq9A== + +postcss@^8.4.17, postcss@^8.4.21, postcss@^8.4.26: + version "8.4.31" + resolved "https://registry.yarnpkg.com/postcss/-/postcss-8.4.31.tgz#92b451050a9f914da6755af352bdc0192508656d" + integrity sha512-PS08Iboia9mts/2ygV3eLpY5ghnUcfLV/EXTOW1E2qYxJKGGBUtNjN76FYHnMs36RmARn41bC0AZmn+rR0OVpQ== + dependencies: + nanoid "^3.3.6" + picocolors "^1.0.0" + source-map-js "^1.0.2" + +pretty-error@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/pretty-error/-/pretty-error-4.0.0.tgz#90a703f46dd7234adb46d0f84823e9d1cb8f10d6" + integrity sha512-AoJ5YMAcXKYxKhuJGdcvse+Voc6v1RgnsR3nWcYU7q4t6z0Q6T86sv5Zq8VIRbOWWFpvdGE83LtdSMNd+6Y0xw== + dependencies: + lodash "^4.17.20" + renderkid "^3.0.0" + +pretty-time@^1.1.0: + version "1.1.0" + resolved "https://registry.yarnpkg.com/pretty-time/-/pretty-time-1.1.0.tgz#ffb7429afabb8535c346a34e41873adf3d74dd0e" + integrity sha512-28iF6xPQrP8Oa6uxE6a1biz+lWeTOAPKggvjB8HAs6nVMKZwf5bG++632Dx614hIWgUPkgivRfG+a8uAXGTIbA== + +prism-react-renderer@^2.1.0: + version "2.3.0" + resolved "https://registry.yarnpkg.com/prism-react-renderer/-/prism-react-renderer-2.3.0.tgz#5f8f615af6af8201a0b734bd8c946df3d818ea54" + integrity sha512-UYRg2TkVIaI6tRVHC5OJ4/BxqPUxJkJvq/odLT/ykpt1zGYXooNperUxQcCvi87LyRnR4nCh81ceOA+e7nrydg== + dependencies: + "@types/prismjs" "^1.26.0" + clsx "^2.0.0" + +prismjs@^1.29.0: + version "1.29.0" + resolved "https://registry.yarnpkg.com/prismjs/-/prismjs-1.29.0.tgz#f113555a8fa9b57c35e637bba27509dcf802dd12" + integrity sha512-Kx/1w86q/epKcmte75LNrEoT+lX8pBpavuAbvJWRXar7Hz8jrtF+e3vY751p0R8H9HdArwaCTNDDzHg/ScJK1Q== + +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== + +promise@^7.1.1: + version "7.3.1" + resolved "https://registry.yarnpkg.com/promise/-/promise-7.3.1.tgz#064b72602b18f90f29192b8b1bc418ffd1ebd3bf" + integrity sha512-nolQXZ/4L+bP/UGlkfaIujX9BKxGwmQ9OT4mOt5yvy8iK1h3wqTEJCijzGANTCCl9nWjY41juyAn2K3Q1hLLTg== + dependencies: + asap "~2.0.3" + +prompts@^2.4.2: + version "2.4.2" + resolved "https://registry.yarnpkg.com/prompts/-/prompts-2.4.2.tgz#7b57e73b3a48029ad10ebd44f74b01722a4cb069" + integrity sha512-NxNv/kLguCA7p3jE8oL2aEBsrJWgAakBpgmgK6lpPWV+WuOmY6r2/zbAVnP+T8bQlA0nzHXSJSJW0Hq7ylaD2Q== + dependencies: + kleur "^3.0.3" + sisteransi "^1.0.5" + +prop-types@^15.6.2, prop-types@^15.7.2: + version "15.8.1" + resolved "https://registry.yarnpkg.com/prop-types/-/prop-types-15.8.1.tgz#67d87bf1a694f48435cf332c24af10214a3140b5" + integrity sha512-oj87CgZICdulUohogVAR7AjlC0327U4el4L6eAvOqCeudMDVU0NThNaV+b9Df4dXgSP1gXMTnPdhfe/2qDH5cg== + dependencies: + loose-envify "^1.4.0" + object-assign "^4.1.1" + react-is "^16.13.1" + +property-information@^6.0.0: + version "6.4.0" + resolved "https://registry.yarnpkg.com/property-information/-/property-information-6.4.0.tgz#6bc4c618b0c2d68b3bb8b552cbb97f8e300a0f82" + integrity sha512-9t5qARVofg2xQqKtytzt+lZ4d1Qvj8t5B8fEwXK6qOfgRLgH/b13QlgEyDh033NOS31nXeFbYv7CLUDG1CeifQ== + +proto-list@~1.2.1: + version "1.2.4" + resolved "https://registry.yarnpkg.com/proto-list/-/proto-list-1.2.4.tgz#212d5bfe1318306a420f6402b8e26ff39647a849" + integrity sha512-vtK/94akxsTMhe0/cbfpR+syPuszcuwhqVjJq26CuNDgFGj682oRBXOP5MJpv2r7JtE8MsiepGIqvvOTBwn2vA== + +proxy-addr@~2.0.7: + version "2.0.7" + resolved "https://registry.yarnpkg.com/proxy-addr/-/proxy-addr-2.0.7.tgz#f19fe69ceab311eeb94b42e70e8c2070f9ba1025" + integrity sha512-llQsMLSUDUPT44jdrU/O37qlnifitDP+ZwrmmZcoSKyLKvtZxpyV0n2/bD/N4tBAAZ/gJEdZU7KMraoK1+XYAg== + dependencies: + forwarded "0.2.0" + ipaddr.js "1.9.1" + +proxy-from-env@^1.1.0: + version "1.1.0" + resolved "https://registry.yarnpkg.com/proxy-from-env/-/proxy-from-env-1.1.0.tgz#e102f16ca355424865755d2c9e8ea4f24d58c3e2" + integrity sha512-D+zkORCbA9f1tdWRK0RaCR3GPv50cMxcrz4X8k5LTSUD1Dkw47mKJEZQNunItRTkWwgtaUSo1RVFRIG9ZXiFYg== + +punycode@^1.3.2: + 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: + version "2.3.1" + resolved "https://registry.yarnpkg.com/punycode/-/punycode-2.3.1.tgz#027422e2faec0b25e1549c3e1bd8309b9133b6e5" + integrity sha512-vYt7UD1U9Wg6138shLtLOvdAu+8DsC/ilFtEVHcH+wydcSpNE20AfSOduf6MkRFahL5FY7X1oU7nKVZFtfq8Fg== + +pupa@^3.1.0: + version "3.1.0" + resolved "https://registry.yarnpkg.com/pupa/-/pupa-3.1.0.tgz#f15610274376bbcc70c9a3aa8b505ea23f41c579" + integrity sha512-FLpr4flz5xZTSJxSeaheeMKN/EDzMdK7b8PTOC6a5PYFKTucWbdqjgqaEyH0shFiSJrVB1+Qqi4Tk19ccU6Aug== + dependencies: + escape-goat "^4.0.0" + +pure-color@^1.2.0: + version "1.3.0" + resolved "https://registry.yarnpkg.com/pure-color/-/pure-color-1.3.0.tgz#1fe064fb0ac851f0de61320a8bf796836422f33e" + integrity sha512-QFADYnsVoBMw1srW7OVKEYjG+MbIa49s54w1MA1EDY6r2r/sTcKKYqRX1f4GYvnXP7eN/Pe9HFcX+hwzmrXRHA== + +qs@6.11.0: + version "6.11.0" + resolved "https://registry.yarnpkg.com/qs/-/qs-6.11.0.tgz#fd0d963446f7a65e1367e01abd85429453f0c37a" + integrity sha512-MvjoMCJwEarSbUYk5O+nmoSzSutSsTwF85zcHPQ9OrlFoZOYIjaqBAJIqIXjptyD5vThxGq52Xu/MaJzRkIk4Q== + dependencies: + side-channel "^1.0.4" + +queue-microtask@^1.2.2: + version "1.2.3" + resolved "https://registry.yarnpkg.com/queue-microtask/-/queue-microtask-1.2.3.tgz#4929228bbc724dfac43e0efb058caf7b6cfb6243" + integrity sha512-NuaNSa6flKT5JaSYQzJok04JzTL1CA6aGhv5rfLW3PgqA+M2ChpZQnAC8h8i4ZFkBS8X5RqkDBHA7r4hej3K9A== + +queue@6.0.2: + version "6.0.2" + resolved "https://registry.yarnpkg.com/queue/-/queue-6.0.2.tgz#b91525283e2315c7553d2efa18d83e76432fed65" + integrity sha512-iHZWu+q3IdFZFX36ro/lKBkSvfkztY5Y7HMiPlOUjhupPcG2JMfst2KKEpu5XndviX/3UhFbRngUPNKtgvtZiA== + dependencies: + inherits "~2.0.3" + +quick-lru@^5.1.1: + version "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.1.0: + 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" + +range-parser@1.2.0: + version "1.2.0" + resolved "https://registry.yarnpkg.com/range-parser/-/range-parser-1.2.0.tgz#f49be6b487894ddc40dcc94a322f611092e00d5e" + integrity sha512-kA5WQoNVo4t9lNx2kQNFCxKeBl5IbbSNBl1M/tLkw9WCn+hxNBAW5Qh8gdhs63CJnhjJ2zQWFoqPJP2sK1AV5A== + +range-parser@^1.2.1, range-parser@~1.2.1: + version "1.2.1" + resolved "https://registry.yarnpkg.com/range-parser/-/range-parser-1.2.1.tgz#3cf37023d199e1c24d1a55b84800c2f3e6468031" + integrity sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg== + +raw-body@2.5.1: + version "2.5.1" + resolved "https://registry.yarnpkg.com/raw-body/-/raw-body-2.5.1.tgz#fe1b1628b181b700215e5fd42389f98b71392857" + integrity sha512-qqJBtEyVgS0ZmPGdCFPWJ3FreoqvG4MVQln/kCgF7Olq95IbOp0/BWyMwbdtn4VTvkM8Y7khCQ2Xgk/tcrCXig== + dependencies: + bytes "3.1.2" + http-errors "2.0.0" + iconv-lite "0.4.24" + unpipe "1.0.0" + +rc@1.2.8: + version "1.2.8" + resolved "https://registry.yarnpkg.com/rc/-/rc-1.2.8.tgz#cd924bf5200a075b83c188cd6b9e211b7fc0d3ed" + integrity sha512-y3bGgqKj3QBdxLbLkomlohkvsA8gdAiUQlSBJnBhfn+BPxg4bc62d8TcBW15wavDfgexCgccckhcZvywyQYPOw== + dependencies: + deep-extend "^0.6.0" + ini "~1.3.0" + minimist "^1.2.0" + strip-json-comments "~2.0.1" + +react-base16-styling@~0.6.0: + version "0.6.0" + resolved "https://registry.yarnpkg.com/react-base16-styling/-/react-base16-styling-0.6.0.tgz#ef2156d66cf4139695c8a167886cb69ea660792c" + integrity sha512-yvh/7CArceR/jNATXOKDlvTnPKPmGZz7zsenQ3jUwLzHkNUR0CvY3yGYJbWJ/nnxsL8Sgmt5cO3/SILVuPO6TQ== + dependencies: + base16 "^1.0.0" + lodash.curry "^4.0.1" + lodash.flow "^3.3.0" + pure-color "^1.2.0" + +react-dev-utils@^12.0.1: + version "12.0.1" + resolved "https://registry.yarnpkg.com/react-dev-utils/-/react-dev-utils-12.0.1.tgz#ba92edb4a1f379bd46ccd6bcd4e7bc398df33e73" + integrity sha512-84Ivxmr17KjUupyqzFode6xKhjwuEJDROWKJy/BthkL7Wn6NJ8h4WE6k/exAv6ImS+0oZLRRW5j/aINMHyeGeQ== + dependencies: + "@babel/code-frame" "^7.16.0" + address "^1.1.2" + browserslist "^4.18.1" + chalk "^4.1.2" + cross-spawn "^7.0.3" + detect-port-alt "^1.1.6" + escape-string-regexp "^4.0.0" + filesize "^8.0.6" + find-up "^5.0.0" + fork-ts-checker-webpack-plugin "^6.5.0" + global-modules "^2.0.0" + globby "^11.0.4" + gzip-size "^6.0.0" + immer "^9.0.7" + is-root "^2.1.0" + loader-utils "^3.2.0" + open "^8.4.0" + pkg-up "^3.1.0" + prompts "^2.4.2" + react-error-overlay "^6.0.11" + recursive-readdir "^2.2.2" + shell-quote "^1.7.3" + strip-ansi "^6.0.1" + text-table "^0.2.0" + +react-dom@^18.0.0: + version "18.2.0" + resolved "https://registry.yarnpkg.com/react-dom/-/react-dom-18.2.0.tgz#22aaf38708db2674ed9ada224ca4aa708d821e3d" + integrity sha512-6IMTriUmvsjHUjNtEDudZfuDQUoWXVxKHhlEGSk81n4YFS+r/Kl99wXiwlVXtPBtJenozv2P+hxDsw9eA7Xo6g== + dependencies: + loose-envify "^1.1.0" + scheduler "^0.23.0" + +react-error-overlay@^6.0.11: + version "6.0.11" + resolved "https://registry.yarnpkg.com/react-error-overlay/-/react-error-overlay-6.0.11.tgz#92835de5841c5cf08ba00ddd2d677b6d17ff9adb" + integrity sha512-/6UZ2qgEyH2aqzYZgQPxEnz33NJ2gNsnHA2o5+o4wW9bLM/JYQitNP9xPhsXwC08hMMovfGe/8retsdDsczPRg== + +react-fast-compare@^3.2.0, react-fast-compare@^3.2.2: + version "3.2.2" + resolved "https://registry.yarnpkg.com/react-fast-compare/-/react-fast-compare-3.2.2.tgz#929a97a532304ce9fee4bcae44234f1ce2c21d49" + integrity sha512-nsO+KSNgo1SbJqJEYRE9ERzo7YtYbou/OqjSQKxV7jcKox7+usiUVZOAC+XnDOABXggQTno0Y1CpVnuWEc1boQ== + +react-helmet-async@*: + version "2.0.1" + resolved "https://registry.yarnpkg.com/react-helmet-async/-/react-helmet-async-2.0.1.tgz#c97e53d03bfe578011e4abbd61113321b0362471" + integrity sha512-SFvEqfhFpLr5xqU6fWFb8wjVPjOR4A5skkNVNN5gAr/QeHutfDe4m1Cdo521umTiFRAY8hDOcl4xJO8sXN1n2Q== + dependencies: + invariant "^2.2.4" + react-fast-compare "^3.2.2" + shallowequal "^1.1.0" + +react-helmet-async@^1.3.0: + version "1.3.0" + resolved "https://registry.yarnpkg.com/react-helmet-async/-/react-helmet-async-1.3.0.tgz#7bd5bf8c5c69ea9f02f6083f14ce33ef545c222e" + integrity sha512-9jZ57/dAn9t3q6hneQS0wukqC2ENOBgMNVEhb/ZG9ZSxUetzVIw4iAmEU38IaVg3QGYauQPhSeUTuIUtFglWpg== + dependencies: + "@babel/runtime" "^7.12.5" + invariant "^2.2.4" + prop-types "^15.7.2" + react-fast-compare "^3.2.0" + shallowequal "^1.1.0" + +react-is@^16.13.1, react-is@^16.6.0, react-is@^16.7.0: + version "16.13.1" + resolved "https://registry.yarnpkg.com/react-is/-/react-is-16.13.1.tgz#789729a4dc36de2999dc156dd6c1d9c18cea56a4" + integrity sha512-24e6ynE2H+OKt4kqsOvNd8kBpV65zoxbA4BVsEOB3ARVWQki/DHzaUoC5KuON/BiccDaCCTZBuOcfZs70kR8bQ== + +react-lifecycles-compat@~3.0.4: + version "3.0.4" + resolved "https://registry.yarnpkg.com/react-lifecycles-compat/-/react-lifecycles-compat-3.0.4.tgz#4f1a273afdfc8f3488a8c516bfda78f872352362" + integrity sha512-fBASbA6LnOU9dOU2eW7aQ8xmYBSXUIWr+UmF9b1efZBazGNO+rcXT/icdKnYm2pTwcRylVUYwW7H1PHfLekVzA== + +react-loadable-ssr-addon-v5-slorber@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/react-loadable-ssr-addon-v5-slorber/-/react-loadable-ssr-addon-v5-slorber-1.0.1.tgz#2cdc91e8a744ffdf9e3556caabeb6e4278689883" + integrity sha512-lq3Lyw1lGku8zUEJPDxsNm1AfYHBrO9Y1+olAYwpUJ2IGFBskM0DMKok97A6LWUpHm+o7IvQBOWu9MLenp9Z+A== + dependencies: + "@babel/runtime" "^7.10.3" + +react-router-config@^5.1.1: + version "5.1.1" + resolved "https://registry.yarnpkg.com/react-router-config/-/react-router-config-5.1.1.tgz#0f4263d1a80c6b2dc7b9c1902c9526478194a988" + integrity sha512-DuanZjaD8mQp1ppHjgnnUnyOlqYXZVjnov/JzFhjLEwd3Z4dYjMSnqrEzzGThH47vpCOqPPwJM2FtthLeJ8Pbg== + dependencies: + "@babel/runtime" "^7.1.2" + +react-router-dom@^5.3.4: + version "5.3.4" + resolved "https://registry.yarnpkg.com/react-router-dom/-/react-router-dom-5.3.4.tgz#2ed62ffd88cae6db134445f4a0c0ae8b91d2e5e6" + integrity sha512-m4EqFMHv/Ih4kpcBCONHbkT68KoAeHN4p3lAGoNryfHi0dMy0kCzEZakiKRsvg5wHZ/JLrLW8o8KomWiz/qbYQ== + dependencies: + "@babel/runtime" "^7.12.13" + history "^4.9.0" + loose-envify "^1.3.1" + prop-types "^15.6.2" + react-router "5.3.4" + tiny-invariant "^1.0.2" + tiny-warning "^1.0.0" + +react-router@5.3.4, react-router@^5.3.4: + version "5.3.4" + resolved "https://registry.yarnpkg.com/react-router/-/react-router-5.3.4.tgz#8ca252d70fcc37841e31473c7a151cf777887bb5" + integrity sha512-Ys9K+ppnJah3QuaRiLxk+jDWOR1MekYQrlytiXxC1RyfbdsZkS5pvKAzCCr031xHixZwpnsYNT5xysdFHQaYsA== + dependencies: + "@babel/runtime" "^7.12.13" + history "^4.9.0" + hoist-non-react-statics "^3.1.0" + loose-envify "^1.3.1" + path-to-regexp "^1.7.0" + prop-types "^15.6.2" + react-is "^16.6.0" + tiny-invariant "^1.0.2" + tiny-warning "^1.0.0" + +react-textarea-autosize@~8.3.2: + version "8.3.4" + resolved "https://registry.yarnpkg.com/react-textarea-autosize/-/react-textarea-autosize-8.3.4.tgz#270a343de7ad350534141b02c9cb78903e553524" + integrity sha512-CdtmP8Dc19xL8/R6sWvtknD/eCXkQr30dtvC4VmGInhRsfF8X/ihXCq6+9l9qbxmKRiq407/7z5fxE7cVWQNgQ== + dependencies: + "@babel/runtime" "^7.10.2" + use-composed-ref "^1.3.0" + use-latest "^1.2.1" + +react@^18.0.0: + version "18.2.0" + resolved "https://registry.yarnpkg.com/react/-/react-18.2.0.tgz#555bd98592883255fa00de14f1151a917b5d77d5" + integrity sha512-/3IjMdb2L9QbBdWiW5e3P2/npwMBaU9mHCSCUzNln0ZCYbcfTsGbTJrU/kGemdH2IWmB2ioZ+zkxtmq6g09fGQ== + dependencies: + loose-envify "^1.1.0" + +readable-stream@^2.0.1: + 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.0.6: + version "3.6.2" + resolved "https://registry.yarnpkg.com/readable-stream/-/readable-stream-3.6.2.tgz#56a9b36ea965c00c5a93ef31eb111a0f11056967" + integrity sha512-9u/sniCrY3D5WdsERHzHE4G2YCXqoG5FTHUiCC4SIbr6XcLZBY05ya9EKjYek9O5xOAwjGq+1JdGBAS7Q9ScoA== + dependencies: + inherits "^2.0.3" + string_decoder "^1.1.1" + util-deprecate "^1.0.1" + +readdirp@~3.6.0: + version "3.6.0" + resolved "https://registry.yarnpkg.com/readdirp/-/readdirp-3.6.0.tgz#74a370bd857116e245b29cc97340cd431a02a6c7" + integrity sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA== + dependencies: + picomatch "^2.2.1" + +reading-time@^1.5.0: + version "1.5.0" + resolved "https://registry.yarnpkg.com/reading-time/-/reading-time-1.5.0.tgz#d2a7f1b6057cb2e169beaf87113cc3411b5bc5bb" + integrity sha512-onYyVhBNr4CmAxFsKS7bz+uTLRakypIe4R+5A824vBSkQy/hB3fZepoVEf8OVAxzLvK+H/jm9TzpI3ETSm64Kg== + +rechoir@^0.6.2: + version "0.6.2" + resolved "https://registry.yarnpkg.com/rechoir/-/rechoir-0.6.2.tgz#85204b54dba82d5742e28c96756ef43af50e3384" + integrity sha512-HFM8rkZ+i3zrV+4LQjwQ0W+ez98pApMGM3HUrN04j3CqzPOzl9nmP15Y8YXNm8QHGv/eacOVEjqhmWpkRV0NAw== + dependencies: + resolve "^1.1.6" + +recursive-readdir@^2.2.2: + version "2.2.3" + resolved "https://registry.yarnpkg.com/recursive-readdir/-/recursive-readdir-2.2.3.tgz#e726f328c0d69153bcabd5c322d3195252379372" + integrity sha512-8HrF5ZsXk5FAH9dgsx3BlUer73nIhuj+9OrQwEbLTPOBzGkL1lsFCR01am+v+0m2Cmbs1nP12hLDl5FA7EszKA== + dependencies: + minimatch "^3.0.5" + +regenerate-unicode-properties@^10.1.0: + version "10.1.1" + resolved "https://registry.yarnpkg.com/regenerate-unicode-properties/-/regenerate-unicode-properties-10.1.1.tgz#6b0e05489d9076b04c436f318d9b067bba459480" + integrity sha512-X007RyZLsCJVVrjgEFVpLUTZwyOZk3oiL75ZcuYjlIWd6rNJtOjkBwQc5AsRrpbKVkxN6sklw/k/9m2jJYOf8Q== + dependencies: + regenerate "^1.4.2" + +regenerate@^1.4.2: + version "1.4.2" + resolved "https://registry.yarnpkg.com/regenerate/-/regenerate-1.4.2.tgz#b9346d8827e8f5a32f7ba29637d398b69014848a" + integrity sha512-zrceR/XhGYU/d/opr2EKO7aRHUeiBI8qjtfHqADTwZd6Szfy16la6kqD0MIUs5z5hx6AaKa+PixpPrR289+I0A== + +regenerator-runtime@^0.14.0: + version "0.14.0" + resolved "https://registry.yarnpkg.com/regenerator-runtime/-/regenerator-runtime-0.14.0.tgz#5e19d68eb12d486f797e15a3c6a918f7cec5eb45" + integrity sha512-srw17NI0TUWHuGa5CFGGmhfNIeja30WMBfbslPNhf6JrqQlLN5gcrvig1oqPxiVaXb0oW0XRKtH6Nngs5lKCIA== + +regenerator-transform@^0.15.2: + version "0.15.2" + resolved "https://registry.yarnpkg.com/regenerator-transform/-/regenerator-transform-0.15.2.tgz#5bbae58b522098ebdf09bca2f83838929001c7a4" + integrity sha512-hfMp2BoF0qOk3uc5V20ALGDS2ddjQaLrdl7xrGXvAIow7qeWRM2VA2HuCHkUKk9slq3VwEwLNK3DFBqDfPGYtg== + dependencies: + "@babel/runtime" "^7.8.4" + +regexpu-core@^5.3.1: + version "5.3.2" + resolved "https://registry.yarnpkg.com/regexpu-core/-/regexpu-core-5.3.2.tgz#11a2b06884f3527aec3e93dbbf4a3b958a95546b" + integrity sha512-RAM5FlZz+Lhmo7db9L298p2vHP5ZywrVXmVXpmAD9GuL5MPH6t9ROw1iA/wfHkQ76Qe7AaPF0nGuim96/IrQMQ== + dependencies: + "@babel/regjsgen" "^0.8.0" + regenerate "^1.4.2" + regenerate-unicode-properties "^10.1.0" + regjsparser "^0.9.1" + unicode-match-property-ecmascript "^2.0.0" + unicode-match-property-value-ecmascript "^2.1.0" + +registry-auth-token@^5.0.1: + version "5.0.2" + resolved "https://registry.yarnpkg.com/registry-auth-token/-/registry-auth-token-5.0.2.tgz#8b026cc507c8552ebbe06724136267e63302f756" + integrity sha512-o/3ikDxtXaA59BmZuZrJZDJv8NMDGSj+6j6XaeBmHw8eY1i1qd9+6H+LjVvQXx3HN6aRCGa1cUdJ9RaJZUugnQ== + dependencies: + "@pnpm/npm-conf" "^2.1.0" + +registry-url@^6.0.0: + version "6.0.1" + resolved "https://registry.yarnpkg.com/registry-url/-/registry-url-6.0.1.tgz#056d9343680f2f64400032b1e199faa692286c58" + integrity sha512-+crtS5QjFRqFCoQmvGduwYWEBng99ZvmFvF+cUJkGYF1L1BfU8C6Zp9T7f5vPAwyLkUExpvK+ANVZmGU49qi4Q== + dependencies: + rc "1.2.8" + +regjsparser@^0.9.1: + version "0.9.1" + resolved "https://registry.yarnpkg.com/regjsparser/-/regjsparser-0.9.1.tgz#272d05aa10c7c1f67095b1ff0addae8442fc5709" + integrity sha512-dQUtn90WanSNl+7mQKcXAgZxvUe7Z0SqXlgzv0za4LwiUhyzBC58yQO3liFoUgu8GiJVInAhJjkj1N0EtQ5nkQ== + dependencies: + jsesc "~0.5.0" + +rehype-raw@^7.0.0: + version "7.0.0" + resolved "https://registry.yarnpkg.com/rehype-raw/-/rehype-raw-7.0.0.tgz#59d7348fd5dbef3807bbaa1d443efd2dd85ecee4" + integrity sha512-/aE8hCfKlQeA8LmyeyQvQF3eBiLRGNlfBJEvWH7ivp9sBqs7TNqBL5X3v157rM4IFETqDnIOO+z5M/biZbo9Ww== + dependencies: + "@types/hast" "^3.0.0" + hast-util-raw "^9.0.0" + vfile "^6.0.0" + +relateurl@^0.2.7: + version "0.2.7" + resolved "https://registry.yarnpkg.com/relateurl/-/relateurl-0.2.7.tgz#54dbf377e51440aca90a4cd274600d3ff2d888a9" + integrity sha512-G08Dxvm4iDN3MLM0EsP62EDV9IuhXPR6blNz6Utcp7zyV3tr4HVNINt6MpaRWbxoOHT3Q7YN2P+jaHX8vUbgog== + +remark-directive@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/remark-directive/-/remark-directive-3.0.0.tgz#34452d951b37e6207d2e2a4f830dc33442923268" + integrity sha512-l1UyWJ6Eg1VPU7Hm/9tt0zKtReJQNOA4+iDMAxTyZNWnJnFlbS/7zhiel/rogTLQ2vMYwDzSJa4BiVNqGlqIMA== + dependencies: + "@types/mdast" "^4.0.0" + mdast-util-directive "^3.0.0" + micromark-extension-directive "^3.0.0" + unified "^11.0.0" + +remark-emoji@^4.0.0: + version "4.0.1" + resolved "https://registry.yarnpkg.com/remark-emoji/-/remark-emoji-4.0.1.tgz#671bfda668047689e26b2078c7356540da299f04" + integrity sha512-fHdvsTR1dHkWKev9eNyhTo4EFwbUvJ8ka9SgeWkMPYFX4WoI7ViVBms3PjlQYgw5TLvNQso3GUB/b/8t3yo+dg== + dependencies: + "@types/mdast" "^4.0.2" + emoticon "^4.0.1" + mdast-util-find-and-replace "^3.0.1" + node-emoji "^2.1.0" + unified "^11.0.4" + +remark-frontmatter@^5.0.0: + version "5.0.0" + resolved "https://registry.yarnpkg.com/remark-frontmatter/-/remark-frontmatter-5.0.0.tgz#b68d61552a421ec412c76f4f66c344627dc187a2" + integrity sha512-XTFYvNASMe5iPN0719nPrdItC9aU0ssC4v14mH1BCi1u0n1gAocqcujWUrByftZTbLhRtiKRyjYTSIOcr69UVQ== + dependencies: + "@types/mdast" "^4.0.0" + mdast-util-frontmatter "^2.0.0" + micromark-extension-frontmatter "^2.0.0" + unified "^11.0.0" + +remark-gfm@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/remark-gfm/-/remark-gfm-4.0.0.tgz#aea777f0744701aa288b67d28c43565c7e8c35de" + integrity sha512-U92vJgBPkbw4Zfu/IiW2oTZLSL3Zpv+uI7My2eq8JxKgqraFdU8YUGicEJCEgSbeaG+QDFqIcwwfMTOEelPxuA== + dependencies: + "@types/mdast" "^4.0.0" + mdast-util-gfm "^3.0.0" + micromark-extension-gfm "^3.0.0" + remark-parse "^11.0.0" + remark-stringify "^11.0.0" + unified "^11.0.0" + +remark-mdx@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/remark-mdx/-/remark-mdx-3.0.0.tgz#146905a3925b078970e05fc89b0e16b9cc3bfddd" + integrity sha512-O7yfjuC6ra3NHPbRVxfflafAj3LTwx3b73aBvkEFU5z4PsD6FD4vrqJAkE5iNGLz71GdjXfgRqm3SQ0h0VuE7g== + dependencies: + mdast-util-mdx "^3.0.0" + micromark-extension-mdxjs "^3.0.0" + +remark-parse@^11.0.0: + version "11.0.0" + resolved "https://registry.yarnpkg.com/remark-parse/-/remark-parse-11.0.0.tgz#aa60743fcb37ebf6b069204eb4da304e40db45a1" + integrity sha512-FCxlKLNGknS5ba/1lmpYijMUzX2esxW5xQqjWxw2eHFfS2MSdaHVINFmhjo+qN1WhZhNimq0dZATN9pH0IDrpA== + dependencies: + "@types/mdast" "^4.0.0" + mdast-util-from-markdown "^2.0.0" + micromark-util-types "^2.0.0" + unified "^11.0.0" + +remark-rehype@^11.0.0: + version "11.0.0" + resolved "https://registry.yarnpkg.com/remark-rehype/-/remark-rehype-11.0.0.tgz#7f21c08738bde024be5f16e4a8b13e5d7a04cf6b" + integrity sha512-vx8x2MDMcxuE4lBmQ46zYUDfcFMmvg80WYX+UNLeG6ixjdCCLcw1lrgAukwBTuOFsS78eoAedHGn9sNM0w7TPw== + dependencies: + "@types/hast" "^3.0.0" + "@types/mdast" "^4.0.0" + mdast-util-to-hast "^13.0.0" + unified "^11.0.0" + vfile "^6.0.0" + +remark-stringify@^11.0.0: + version "11.0.0" + resolved "https://registry.yarnpkg.com/remark-stringify/-/remark-stringify-11.0.0.tgz#4c5b01dd711c269df1aaae11743eb7e2e7636fd3" + integrity sha512-1OSmLd3awB/t8qdoEOMazZkNsfVTeY4fTsgzcQFdXNq8ToTN4ZGwrMnlda4K6smTFKD+GRV6O48i6Z4iKgPPpw== + dependencies: + "@types/mdast" "^4.0.0" + mdast-util-to-markdown "^2.0.0" + unified "^11.0.0" + +renderkid@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/renderkid/-/renderkid-3.0.0.tgz#5fd823e4d6951d37358ecc9a58b1f06836b6268a" + integrity sha512-q/7VIQA8lmM1hF+jn+sFSPWGlMkSAeNYcPLmDQx2zzuiDfaLrOmumR8iaUKlenFgh0XRPIUeSPlH3A+AW3Z5pg== + dependencies: + css-select "^4.1.3" + dom-converter "^0.2.0" + htmlparser2 "^6.1.0" + lodash "^4.17.21" + strip-ansi "^6.0.1" + +require-from-string@^2.0.2: + version "2.0.2" + resolved "https://registry.yarnpkg.com/require-from-string/-/require-from-string-2.0.2.tgz#89a7fdd938261267318eafe14f9c32e598c36909" + integrity sha512-Xf0nWe6RseziFMu+Ap9biiUbmplq6S9/p+7w7YXP/JBHhrUDDUhwa+vANyubuqfZWTveU//DYVGsDG7RKL/vEw== + +"require-like@>= 0.1.1": + version "0.1.2" + resolved "https://registry.yarnpkg.com/require-like/-/require-like-0.1.2.tgz#ad6f30c13becd797010c468afa775c0c0a6b47fa" + integrity sha512-oyrU88skkMtDdauHDuKVrgR+zuItqr6/c//FXzvmxRGMexSDc6hNvJInGW3LL46n+8b50RykrvwSUIIQH2LQ5A== + +requires-port@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/requires-port/-/requires-port-1.0.0.tgz#925d2601d39ac485e091cf0da5c6e694dc3dcaff" + integrity sha512-KigOCHcocU3XODJxsu8i/j8T9tzT4adHiecwORRQ0ZZFcp7ahwXuRU1m+yuO90C5ZUyGeGfocHDI14M3L3yDAQ== + +resolve-alpn@^1.2.0: + version "1.2.1" + resolved "https://registry.yarnpkg.com/resolve-alpn/-/resolve-alpn-1.2.1.tgz#b7adbdac3546aaaec20b45e7d8265927072726f9" + integrity sha512-0a1F4l73/ZFZOakJnQ3FvkJ2+gSTQWz/r2KE5OdDY0TxPm5h4GkqkWWfM47T7HsbnOtcJVEF4epCVy6u7Q3K+g== + +resolve-from@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/resolve-from/-/resolve-from-4.0.0.tgz#4abcd852ad32dd7baabfe9b40e00a36db5f392e6" + integrity sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g== + +resolve-pathname@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/resolve-pathname/-/resolve-pathname-3.0.0.tgz#99d02224d3cf263689becbb393bc560313025dcd" + integrity sha512-C7rARubxI8bXFNB/hqcp/4iUeIXJhJZvFPFPiSPRnhU5UPxzMFIl+2E6yY6c4k9giDJAhtV+enfA+G89N6Csng== + +resolve@^1.1.6, resolve@^1.14.2: + version "1.22.8" + resolved "https://registry.yarnpkg.com/resolve/-/resolve-1.22.8.tgz#b6c87a9f2aa06dfab52e3d70ac8cde321fa5a48d" + integrity sha512-oKWePCxqpd6FlLvGV1VU0x7bkPmmCNolxzjMf4NczoDnQcIWrAF+cPtZn5i6n+RfD2d9i0tzpKnG6Yk168yIyw== + dependencies: + is-core-module "^2.13.0" + path-parse "^1.0.7" + supports-preserve-symlinks-flag "^1.0.0" + +responselike@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/responselike/-/responselike-3.0.0.tgz#20decb6c298aff0dbee1c355ca95461d42823626" + integrity sha512-40yHxbNcl2+rzXvZuVkrYohathsSJlMTXKryG5y8uciHv1+xDLHQpgjG64JUO9nrEq2jGLH6IZ8BcZyw3wrweg== + dependencies: + lowercase-keys "^3.0.0" + +retry@^0.13.1: + version "0.13.1" + resolved "https://registry.yarnpkg.com/retry/-/retry-0.13.1.tgz#185b1587acf67919d63b357349e03537b2484658" + integrity sha512-XQBQ3I8W1Cge0Seh+6gjj03LbmRFWuoszgK9ooCpwYIrhhoO80pfq4cUkU5DkknwfOfFteRwlZ56PYOGYyFWdg== + +reusify@^1.0.4: + version "1.0.4" + resolved "https://registry.yarnpkg.com/reusify/-/reusify-1.0.4.tgz#90da382b1e126efc02146e90845a88db12925d76" + integrity sha512-U9nH88a3fc/ekCF1l0/UP1IosiuIjyTh7hBvXVMHYgVcfGvt897Xguj2UOLDeI5BG2m7/uwyaLVT6fbtCwTyzw== + +rimraf@^3.0.2: + version "3.0.2" + resolved "https://registry.yarnpkg.com/rimraf/-/rimraf-3.0.2.tgz#f1a5402ba6220ad52cc1282bac1ae3aa49fd061a" + integrity sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA== + dependencies: + glob "^7.1.3" + +rtl-detect@^1.0.4: + version "1.1.2" + resolved "https://registry.yarnpkg.com/rtl-detect/-/rtl-detect-1.1.2.tgz#ca7f0330af5c6bb626c15675c642ba85ad6273c6" + integrity sha512-PGMBq03+TTG/p/cRB7HCLKJ1MgDIi07+QU1faSjiYRfmY5UsAttV9Hs08jDAHVwcOwmVLcSJkpwyfXszVjWfIQ== + +rtlcss@^4.1.0: + version "4.1.1" + resolved "https://registry.yarnpkg.com/rtlcss/-/rtlcss-4.1.1.tgz#f20409fcc197e47d1925996372be196fee900c0c" + integrity sha512-/oVHgBtnPNcggP2aVXQjSy6N1mMAfHg4GSag0QtZBlD5bdDgAHwr4pydqJGd+SUCu9260+Pjqbjwtvu7EMH1KQ== + dependencies: + escalade "^3.1.1" + picocolors "^1.0.0" + postcss "^8.4.21" + strip-json-comments "^3.1.1" + +run-parallel@^1.1.9: + version "1.2.0" + resolved "https://registry.yarnpkg.com/run-parallel/-/run-parallel-1.2.0.tgz#66d1368da7bdf921eb9d95bd1a9229e7f21a43ee" + integrity sha512-5l4VyZR86LZ/lDxZTR6jqL8AFE2S0IFLMP26AbjsLVADxHdhB/c0GUsH+y39UfCi3dzz8OlQuPmnaJOMoDHQBA== + dependencies: + queue-microtask "^1.2.2" + +rxjs@^7.8.1: + version "7.8.1" + resolved "https://registry.yarnpkg.com/rxjs/-/rxjs-7.8.1.tgz#6f6f3d99ea8044291efd92e7c7fcf562c4057543" + integrity sha512-AA3TVj+0A2iuIoQkWEK/tqFjBq2j+6PO6Y0zJcvzLAFhEFIO3HL0vls9hWLncZbAAbK0mar7oZ4V079I/qPMxg== + dependencies: + tslib "^2.1.0" + +safe-buffer@5.1.2, 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== + +safe-buffer@5.2.1, safe-buffer@>=5.1.0, safe-buffer@^5.1.0, 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== + +"safer-buffer@>= 2.1.2 < 3": + version "2.1.2" + resolved "https://registry.yarnpkg.com/safer-buffer/-/safer-buffer-2.1.2.tgz#44fa161b0187b9549dd84bb91802f9bd8385cd6a" + integrity sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg== + +sax@^1.2.4: + version "1.3.0" + resolved "https://registry.yarnpkg.com/sax/-/sax-1.3.0.tgz#a5dbe77db3be05c9d1ee7785dbd3ea9de51593d0" + integrity sha512-0s+oAmw9zLl1V1cS9BtZN7JAd0cW5e0QH4W3LWEK6a4LaLEA2OTpGYWDY+6XasBLtz6wkm3u1xRw95mRuJ59WA== + +scheduler@^0.23.0: + version "0.23.0" + resolved "https://registry.yarnpkg.com/scheduler/-/scheduler-0.23.0.tgz#ba8041afc3d30eb206a487b6b384002e4e61fdfe" + integrity sha512-CtuThmgHNg7zIZWAXi3AsyIzA3n4xx7aNyjwC2VJldO2LMVDhFK+63xGqq6CsJH4rTAt6/M+N4GhZiDYPx9eUw== + dependencies: + loose-envify "^1.1.0" + +schema-utils@2.7.0: + version "2.7.0" + resolved "https://registry.yarnpkg.com/schema-utils/-/schema-utils-2.7.0.tgz#17151f76d8eae67fbbf77960c33c676ad9f4efc7" + integrity sha512-0ilKFI6QQF5nxDZLFn2dMjvc4hjg/Wkg7rHd3jK6/A4a1Hl9VFdQWvgB1UMGoU94pad1P/8N7fMcEnLnSiju8A== + dependencies: + "@types/json-schema" "^7.0.4" + ajv "^6.12.2" + ajv-keywords "^3.4.1" + +schema-utils@^3.0.0, schema-utils@^3.1.1, schema-utils@^3.2.0: + version "3.3.0" + resolved "https://registry.yarnpkg.com/schema-utils/-/schema-utils-3.3.0.tgz#f50a88877c3c01652a15b622ae9e9795df7a60fe" + integrity sha512-pN/yOAvcC+5rQ5nERGuwrjLlYvLTbCibnZ1I7B1LaiAz9BRBlE9GMgE/eqV30P7aJQUf7Ddimy/RsbYO/GrVGg== + dependencies: + "@types/json-schema" "^7.0.8" + ajv "^6.12.5" + ajv-keywords "^3.5.2" + +schema-utils@^4.0.0: + version "4.2.0" + resolved "https://registry.yarnpkg.com/schema-utils/-/schema-utils-4.2.0.tgz#70d7c93e153a273a805801882ebd3bff20d89c8b" + integrity sha512-L0jRsrPpjdckP3oPug3/VxNKt2trR8TcabrM6FOAAlvC/9Phcmm+cuAgTlxBqdBR1WJx7Naj9WHw+aOmheSVbw== + dependencies: + "@types/json-schema" "^7.0.9" + ajv "^8.9.0" + ajv-formats "^2.1.1" + ajv-keywords "^5.1.0" + +section-matter@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/section-matter/-/section-matter-1.0.0.tgz#e9041953506780ec01d59f292a19c7b850b84167" + integrity sha512-vfD3pmTzGpufjScBh50YHKzEu2lxBWhVEHsNGoEXmCmn2hKGfeNLYMzCJpe8cD7gqX7TJluOVpBkAequ6dgMmA== + dependencies: + extend-shallow "^2.0.1" + kind-of "^6.0.0" + +select-hose@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/select-hose/-/select-hose-2.0.0.tgz#625d8658f865af43ec962bfc376a37359a4994ca" + integrity sha512-mEugaLK+YfkijB4fx0e6kImuJdCIt2LxCRcbEYPqRGCs4F2ogyfZU5IAZRdjCP8JPq2AtdNoC/Dux63d9Kiryg== + +selfsigned@^2.1.1: + version "2.4.1" + resolved "https://registry.yarnpkg.com/selfsigned/-/selfsigned-2.4.1.tgz#560d90565442a3ed35b674034cec4e95dceb4ae0" + integrity sha512-th5B4L2U+eGLq1TVh7zNRGBapioSORUeymIydxgFpwww9d2qyKvtuPU2jJuHvYAwwqi2Y596QBL3eEqcPEYL8Q== + dependencies: + "@types/node-forge" "^1.3.0" + node-forge "^1" + +semver-diff@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/semver-diff/-/semver-diff-4.0.0.tgz#3afcf5ed6d62259f5c72d0d5d50dffbdc9680df5" + integrity sha512-0Ju4+6A8iOnpL/Thra7dZsSlOHYAHIeMxfhWQRI1/VLcT3WDBZKKtQt/QkBOsiIN9ZpuvHE6cGZ0x4glCMmfiA== + dependencies: + semver "^7.3.5" + +semver@^6.3.1: + version "6.3.1" + resolved "https://registry.yarnpkg.com/semver/-/semver-6.3.1.tgz#556d2ef8689146e46dcea4bfdd095f3434dffcb4" + integrity sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA== + +semver@^7.3.2, semver@^7.3.5, semver@^7.3.7, semver@^7.3.8, semver@^7.5.4: + version "7.5.4" + resolved "https://registry.yarnpkg.com/semver/-/semver-7.5.4.tgz#483986ec4ed38e1c6c48c34894a9182dbff68a6e" + integrity sha512-1bCSESV6Pv+i21Hvpxp3Dx+pSD8lIPt8uVjRrxAUt/nbswYc+tK6Y2btiULjd4+fnq15PX+nqQDC7Oft7WkwcA== + dependencies: + lru-cache "^6.0.0" + +send@0.18.0: + version "0.18.0" + resolved "https://registry.yarnpkg.com/send/-/send-0.18.0.tgz#670167cc654b05f5aa4a767f9113bb371bc706be" + integrity sha512-qqWzuOjSFOuqPjFe4NOsMLafToQQwBSOEpS+FwEt3A2V3vKubTquT3vmLTQpFgMXp8AlFWFuP1qKaJZOtPpVXg== + dependencies: + debug "2.6.9" + depd "2.0.0" + destroy "1.2.0" + encodeurl "~1.0.2" + escape-html "~1.0.3" + etag "~1.8.1" + fresh "0.5.2" + http-errors "2.0.0" + mime "1.6.0" + ms "2.1.3" + on-finished "2.4.1" + range-parser "~1.2.1" + statuses "2.0.1" + +serialize-javascript@^6.0.0, serialize-javascript@^6.0.1: + version "6.0.1" + resolved "https://registry.yarnpkg.com/serialize-javascript/-/serialize-javascript-6.0.1.tgz#b206efb27c3da0b0ab6b52f48d170b7996458e5c" + integrity sha512-owoXEFjWRllis8/M1Q+Cw5k8ZH40e3zhp/ovX+Xr/vi1qj6QesbyXXViFbpNvWvPNAD62SutwEXavefrLJWj7w== + dependencies: + randombytes "^2.1.0" + +serve-handler@^6.1.5: + version "6.1.5" + resolved "https://registry.yarnpkg.com/serve-handler/-/serve-handler-6.1.5.tgz#a4a0964f5c55c7e37a02a633232b6f0d6f068375" + integrity sha512-ijPFle6Hwe8zfmBxJdE+5fta53fdIY0lHISJvuikXB3VYFafRjMRpOffSPvCYsbKyBA7pvy9oYr/BT1O3EArlg== + dependencies: + bytes "3.0.0" + content-disposition "0.5.2" + fast-url-parser "1.1.3" + mime-types "2.1.18" + minimatch "3.1.2" + path-is-inside "1.0.2" + path-to-regexp "2.2.1" + range-parser "1.2.0" + +serve-index@^1.9.1: + version "1.9.1" + resolved "https://registry.yarnpkg.com/serve-index/-/serve-index-1.9.1.tgz#d3768d69b1e7d82e5ce050fff5b453bea12a9239" + integrity sha512-pXHfKNP4qujrtteMrSBb0rc8HJ9Ms/GrXwcUtUtD5s4ewDJI8bT3Cz2zTVRMKtri49pLx2e0Ya8ziP5Ya2pZZw== + dependencies: + accepts "~1.3.4" + batch "0.6.1" + debug "2.6.9" + escape-html "~1.0.3" + http-errors "~1.6.2" + mime-types "~2.1.17" + parseurl "~1.3.2" + +serve-static@1.15.0: + version "1.15.0" + resolved "https://registry.yarnpkg.com/serve-static/-/serve-static-1.15.0.tgz#faaef08cffe0a1a62f60cad0c4e513cff0ac9540" + integrity sha512-XGuRDNjXUijsUL0vl6nSD7cwURuzEgglbOaFuZM9g3kwDXOWVTck0jLzjPzGD+TazWbboZYu52/9/XPdUgne9g== + dependencies: + encodeurl "~1.0.2" + escape-html "~1.0.3" + parseurl "~1.3.3" + send "0.18.0" + +set-function-length@^1.1.1: + version "1.1.1" + resolved "https://registry.yarnpkg.com/set-function-length/-/set-function-length-1.1.1.tgz#4bc39fafb0307224a33e106a7d35ca1218d659ed" + integrity sha512-VoaqjbBJKiWtg4yRcKBQ7g7wnGnLV3M8oLvVWwOk2PdYY6PEFegR1vezXR0tw6fZGF9csVakIRjrJiy2veSBFQ== + dependencies: + define-data-property "^1.1.1" + get-intrinsic "^1.2.1" + gopd "^1.0.1" + has-property-descriptors "^1.0.0" + +setimmediate@^1.0.5: + 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== + +setprototypeof@1.1.0: + version "1.1.0" + resolved "https://registry.yarnpkg.com/setprototypeof/-/setprototypeof-1.1.0.tgz#d0bd85536887b6fe7c0d818cb962d9d91c54e656" + integrity sha512-BvE/TwpZX4FXExxOxZyRGQQv651MSwmWKZGqvmPcRIjDqWub67kTKuIMx43cZZrS/cBBzwBcNDWoFxt2XEFIpQ== + +setprototypeof@1.2.0: + version "1.2.0" + resolved "https://registry.yarnpkg.com/setprototypeof/-/setprototypeof-1.2.0.tgz#66c9a24a73f9fc28cbe66b09fed3d33dcaf1b424" + integrity sha512-E5LDX7Wrp85Kil5bhZv46j8jOeboKq5JMmYM3gVGdGH8xFpPWXUMsNrlODCrkoxMEeNi/XZIwuRvY4XNwYMJpw== + +shallow-clone@^3.0.0: + version "3.0.1" + resolved "https://registry.yarnpkg.com/shallow-clone/-/shallow-clone-3.0.1.tgz#8f2981ad92531f55035b01fb230769a40e02efa3" + integrity sha512-/6KqX+GVUdqPuPPd2LxDDxzX6CAbjJehAAOKlNpqqUpAqPM6HeL8f+o3a+JsyGjn2lv0WY8UsTgUJjU9Ok55NA== + dependencies: + kind-of "^6.0.2" + +shallowequal@^1.1.0: + version "1.1.0" + resolved "https://registry.yarnpkg.com/shallowequal/-/shallowequal-1.1.0.tgz#188d521de95b9087404fd4dcb68b13df0ae4e7f8" + integrity sha512-y0m1JoUZSlPAjXVtPPW70aZWfIL/dSP7AFkRnniLCrK/8MDKog3TySTBmckD+RObVxH0v4Tox67+F14PdED2oQ== + +shebang-command@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/shebang-command/-/shebang-command-2.0.0.tgz#ccd0af4f8835fbdc265b82461aaf0c36663f34ea" + integrity sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA== + dependencies: + shebang-regex "^3.0.0" + +shebang-regex@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/shebang-regex/-/shebang-regex-3.0.0.tgz#ae16f1644d873ecad843b0307b143362d4c42172" + integrity sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A== + +shell-quote@^1.7.3, shell-quote@^1.8.1: + version "1.8.1" + resolved "https://registry.yarnpkg.com/shell-quote/-/shell-quote-1.8.1.tgz#6dbf4db75515ad5bac63b4f1894c3a154c766680" + integrity sha512-6j1W9l1iAs/4xYBI1SYOVZyFcCis9b4KCLQ8fgAGG07QvzaRLVVRQvAy85yNmmZSjYjg4MWh4gNvlPujU/5LpA== + +shelljs@^0.8.5: + version "0.8.5" + resolved "https://registry.yarnpkg.com/shelljs/-/shelljs-0.8.5.tgz#de055408d8361bed66c669d2f000538ced8ee20c" + integrity sha512-TiwcRcrkhHvbrZbnRcFYMLl30Dfov3HKqzp5tO5b4pt6G/SezKcYhmDg15zXVBswHmctSAQKznqNW2LO5tTDow== + dependencies: + glob "^7.0.0" + interpret "^1.0.0" + rechoir "^0.6.2" + +shiki@^0.14.1: + version "0.14.5" + resolved "https://registry.yarnpkg.com/shiki/-/shiki-0.14.5.tgz#375dd214e57eccb04f0daf35a32aa615861deb93" + integrity sha512-1gCAYOcmCFONmErGTrS1fjzJLA7MGZmKzrBNX7apqSwhyITJg2O102uFzXUeBxNnEkDA9vHIKLyeKq0V083vIw== + dependencies: + ansi-sequence-parser "^1.1.0" + jsonc-parser "^3.2.0" + vscode-oniguruma "^1.7.0" + vscode-textmate "^8.0.0" + +side-channel@^1.0.4: + version "1.0.4" + resolved "https://registry.yarnpkg.com/side-channel/-/side-channel-1.0.4.tgz#efce5c8fdc104ee751b25c58d4290011fa5ea2cf" + integrity sha512-q5XPytqFEIKHkGdiMIrY10mvLRvnQh42/+GoBlFW3b2LXLE2xxJpZFdm94we0BaoV3RwJyGqg5wS7epxTv0Zvw== + dependencies: + call-bind "^1.0.0" + get-intrinsic "^1.0.2" + object-inspect "^1.9.0" + +signal-exit@^3.0.2, signal-exit@^3.0.3: + version "3.0.7" + resolved "https://registry.yarnpkg.com/signal-exit/-/signal-exit-3.0.7.tgz#a9a1767f8af84155114eaabd73f99273c8f59ad9" + integrity sha512-wnD2ZE+l+SPC/uoS0vXeE9L1+0wuaMqKlfz9AMUo38JsyLSBWSFcHR1Rri62LZc12vLr1gb3jl7iwQhgwpAbGQ== + +sirv@^2.0.3: + version "2.0.3" + resolved "https://registry.yarnpkg.com/sirv/-/sirv-2.0.3.tgz#ca5868b87205a74bef62a469ed0296abceccd446" + integrity sha512-O9jm9BsID1P+0HOi81VpXPoDxYP374pkOLzACAoyUQ/3OUVndNpsz6wMnY2z+yOxzbllCKZrM+9QrWsv4THnyA== + dependencies: + "@polka/url" "^1.0.0-next.20" + mrmime "^1.0.0" + totalist "^3.0.0" + +sisteransi@^1.0.5: + version "1.0.5" + resolved "https://registry.yarnpkg.com/sisteransi/-/sisteransi-1.0.5.tgz#134d681297756437cc05ca01370d3a7a571075ed" + integrity sha512-bLGGlR1QxBcynn2d5YmDX4MGjlZvy2MRBDRNHLJ8VI6l6+9FUiyTFNJ0IveOSP0bcXgVDPRcfGqA0pjaqUpfVg== + +sitemap@^7.1.1: + version "7.1.1" + resolved "https://registry.yarnpkg.com/sitemap/-/sitemap-7.1.1.tgz#eeed9ad6d95499161a3eadc60f8c6dce4bea2bef" + integrity sha512-mK3aFtjz4VdJN0igpIJrinf3EO8U8mxOPsTBzSsy06UtjZQJ3YY3o3Xa7zSc5nMqcMrRwlChHZ18Kxg0caiPBg== + dependencies: + "@types/node" "^17.0.5" + "@types/sax" "^1.2.1" + arg "^5.0.0" + sax "^1.2.4" + +skin-tone@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/skin-tone/-/skin-tone-2.0.0.tgz#4e3933ab45c0d4f4f781745d64b9f4c208e41237" + integrity sha512-kUMbT1oBJCpgrnKoSr0o6wPtvRWT9W9UKvGLwfJYO2WuahZRHOpEyL1ckyMGgMWh0UdpmaoFqKKD29WTomNEGA== + dependencies: + unicode-emoji-modifier-base "^1.0.0" + +slash@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/slash/-/slash-3.0.0.tgz#6539be870c165adbd5240220dbe361f1bc4d4634" + integrity sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q== + +slash@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/slash/-/slash-4.0.0.tgz#2422372176c4c6c5addb5e2ada885af984b396a7" + integrity sha512-3dOsAHXXUkQTpOYcoAxLIorMTp4gIQr5IW3iVb7A7lFIp0VHhnynm9izx6TssdrIcVIESAlVjtnO2K8bg+Coew== + +sockjs@^0.3.24: + version "0.3.24" + resolved "https://registry.yarnpkg.com/sockjs/-/sockjs-0.3.24.tgz#c9bc8995f33a111bea0395ec30aa3206bdb5ccce" + integrity sha512-GJgLTZ7vYb/JtPSSZ10hsOYIvEYsjbNU+zPdIHcUaWVNUEPivzxku31865sSSud0Da0W4lEeOPlmw93zLQchuQ== + dependencies: + faye-websocket "^0.11.3" + uuid "^8.3.2" + websocket-driver "^0.7.4" + +sort-css-media-queries@2.1.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/sort-css-media-queries/-/sort-css-media-queries-2.1.0.tgz#7c85e06f79826baabb232f5560e9745d7a78c4ce" + integrity sha512-IeWvo8NkNiY2vVYdPa27MCQiR0MN0M80johAYFVxWWXQ44KU84WNxjslwBHmc/7ZL2ccwkM7/e6S5aiKZXm7jA== + +source-map-js@^1.0.2: + version "1.0.2" + resolved "https://registry.yarnpkg.com/source-map-js/-/source-map-js-1.0.2.tgz#adbc361d9c62df380125e7f161f71c826f1e490c" + integrity sha512-R0XvVJ9WusLiqTCEiGCmICCMplcCkIwwR11mOSD9CR5u+IXYdiseeEuXCVAjS54zqwkLcPNnmU4OeJ6tUrWhDw== + +source-map-support@~0.5.20: + version "0.5.21" + resolved "https://registry.yarnpkg.com/source-map-support/-/source-map-support-0.5.21.tgz#04fe7c7f9e1ed2d662233c28cb2b35b9f63f6e4f" + integrity sha512-uBHU3L3czsIyYXKX88fdrGovxdSCoTGDRZ6SYXtSRxLZUzHg5P/66Ht6uoUlHu9EZod+inXhKo3qQgwXUT/y1w== + dependencies: + buffer-from "^1.0.0" + source-map "^0.6.0" + +source-map@^0.6.0, source-map@^0.6.1, source-map@~0.6.0: + version "0.6.1" + resolved "https://registry.yarnpkg.com/source-map/-/source-map-0.6.1.tgz#74722af32e9614e9c287a8d0bbde48b5e2f1a263" + integrity sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g== + +source-map@^0.7.0: + version "0.7.4" + resolved "https://registry.yarnpkg.com/source-map/-/source-map-0.7.4.tgz#a9bbe705c9d8846f4e08ff6765acf0f1b0898656" + integrity sha512-l3BikUxvPOcn5E74dZiq5BGsTb5yEwhaTSzccU6t4sDOH8NWJCstKO5QT2CvtFoK6F0saL7p9xHAqHOlCPJygA== + +space-separated-tokens@^2.0.0: + version "2.0.2" + resolved "https://registry.yarnpkg.com/space-separated-tokens/-/space-separated-tokens-2.0.2.tgz#1ecd9d2350a3844572c3f4a312bceb018348859f" + integrity sha512-PEGlAwrG8yXGXRjW32fGbg66JAlOAwbObuqVoJpv/mRgoWDQfgH1wDPvtzWyUSNAXBGSk8h755YDbbcEy3SH2Q== + +spdy-transport@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/spdy-transport/-/spdy-transport-3.0.0.tgz#00d4863a6400ad75df93361a1608605e5dcdcf31" + integrity sha512-hsLVFE5SjA6TCisWeJXFKniGGOpBgMLmerfO2aCyCU5s7nJ/rpAepqmFifv/GCbSbueEeAJJnmSQ2rKC/g8Fcw== + dependencies: + debug "^4.1.0" + detect-node "^2.0.4" + hpack.js "^2.1.6" + obuf "^1.1.2" + readable-stream "^3.0.6" + wbuf "^1.7.3" + +spdy@^4.0.2: + version "4.0.2" + resolved "https://registry.yarnpkg.com/spdy/-/spdy-4.0.2.tgz#b74f466203a3eda452c02492b91fb9e84a27677b" + integrity sha512-r46gZQZQV+Kl9oItvl1JZZqJKGr+oEkB08A6BzkiR7593/7IbtuncXHd2YoYeTsG4157ZssMu9KYvUHLcjcDoA== + dependencies: + debug "^4.1.0" + handle-thing "^2.0.0" + http-deceiver "^1.2.7" + select-hose "^2.0.0" + spdy-transport "^3.0.0" + +sprintf-js@~1.0.2: + version "1.0.3" + resolved "https://registry.yarnpkg.com/sprintf-js/-/sprintf-js-1.0.3.tgz#04e6926f662895354f3dd015203633b857297e2c" + integrity sha512-D9cPgkvLlV3t3IzL0D0YLvGA9Ahk4PcvVwUbN0dSGr1aP0Nrt4AEnTUbuGvquEC0mA64Gqt1fzirlRs5ibXx8g== + +srcset@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/srcset/-/srcset-4.0.0.tgz#336816b665b14cd013ba545b6fe62357f86e65f4" + integrity sha512-wvLeHgcVHKO8Sc/H/5lkGreJQVeYMm9rlmt8PuR1xE31rIuXhuzznUUqAt8MqLhB3MqJdFzlNAfpcWnxiFUcPw== + +stable@^0.1.8: + version "0.1.8" + resolved "https://registry.yarnpkg.com/stable/-/stable-0.1.8.tgz#836eb3c8382fe2936feaf544631017ce7d47a3cf" + integrity sha512-ji9qxRnOVfcuLDySj9qzhGSEFVobyt1kIOSkj1qZzYLzq7Tos/oUUWvotUPQLlrsidqsK6tBH89Bc9kL5zHA6w== + +statuses@2.0.1: + version "2.0.1" + resolved "https://registry.yarnpkg.com/statuses/-/statuses-2.0.1.tgz#55cb000ccf1d48728bd23c685a063998cf1a1b63" + integrity sha512-RwNA9Z/7PrK06rYLIzFMlaF+l73iwpzsqRIFgbMLbTcLD6cOao82TaWefPXQvB2fOC4AjuYSEndS7N/mTCbkdQ== + +"statuses@>= 1.4.0 < 2": + version "1.5.0" + resolved "https://registry.yarnpkg.com/statuses/-/statuses-1.5.0.tgz#161c7dac177659fd9811f43771fa99381478628c" + integrity sha512-OpZ3zP+jT1PI7I8nemJX4AKmAX070ZkYPVWV/AaKTJl+tXCTGyVdC1a4SL8RUQYEwk/f34ZX8UTykN68FwrqAA== + +std-env@^3.0.1: + version "3.5.0" + resolved "https://registry.yarnpkg.com/std-env/-/std-env-3.5.0.tgz#83010c9e29bd99bf6f605df87c19012d82d63b97" + integrity sha512-JGUEaALvL0Mf6JCfYnJOTcobY+Nc7sG/TemDRBqCA0wEr4DER7zDchaaixTlmOxAjG1uRJmX82EQcxwTQTkqVA== + +string-width@^4.1.0, string-width@^4.2.0: + version "4.2.3" + resolved "https://registry.yarnpkg.com/string-width/-/string-width-4.2.3.tgz#269c7117d27b05ad2e536830a8ec895ef9c6d010" + integrity sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g== + dependencies: + emoji-regex "^8.0.0" + is-fullwidth-code-point "^3.0.0" + strip-ansi "^6.0.1" + +string-width@^5.0.1, string-width@^5.1.2: + version "5.1.2" + resolved "https://registry.yarnpkg.com/string-width/-/string-width-5.1.2.tgz#14f8daec6d81e7221d2a357e668cab73bdbca794" + integrity sha512-HnLOCR3vjcY8beoNLtcjZ5/nxn2afmME6lhrDrebokqMap+XbeW8n9TXpPDOqdGK5qcI3oT0GKTW6wC7EMiVqA== + dependencies: + eastasianwidth "^0.2.0" + emoji-regex "^9.2.2" + strip-ansi "^7.0.1" + +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" + +stringify-entities@^4.0.0: + version "4.0.3" + resolved "https://registry.yarnpkg.com/stringify-entities/-/stringify-entities-4.0.3.tgz#cfabd7039d22ad30f3cc435b0ca2c1574fc88ef8" + integrity sha512-BP9nNHMhhfcMbiuQKCqMjhDP5yBCAxsPu4pHFFzJ6Alo9dZgY4VLDPutXqIjpRiMoKdp7Av85Gr73Q5uH9k7+g== + dependencies: + character-entities-html4 "^2.0.0" + character-entities-legacy "^3.0.0" + +stringify-object@^3.3.0: + version "3.3.0" + resolved "https://registry.yarnpkg.com/stringify-object/-/stringify-object-3.3.0.tgz#703065aefca19300d3ce88af4f5b3956d7556629" + integrity sha512-rHqiFh1elqCQ9WPLIC8I0Q/g/wj5J1eMkyoiD6eoQApWHP0FtlK7rqnhmabL5VUY9JQCcqwwvlOaSuutekgyrw== + dependencies: + get-own-enumerable-property-symbols "^3.0.0" + is-obj "^1.0.1" + is-regexp "^1.0.0" + +strip-ansi@^6.0.1: + version "6.0.1" + resolved "https://registry.yarnpkg.com/strip-ansi/-/strip-ansi-6.0.1.tgz#9e26c63d30f53443e9489495b2105d37b67a85d9" + integrity sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A== + dependencies: + ansi-regex "^5.0.1" + +strip-ansi@^7.0.1: + version "7.1.0" + resolved "https://registry.yarnpkg.com/strip-ansi/-/strip-ansi-7.1.0.tgz#d5b6568ca689d8561370b0707685d22434faff45" + integrity sha512-iq6eVVI64nQQTRYq2KtEg2d2uU7LElhTJwsH4YzIHZshxlgZms/wIc4VoDQTlG/IvVIrBKG06CrZnp0qv7hkcQ== + dependencies: + ansi-regex "^6.0.1" + +strip-bom-string@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/strip-bom-string/-/strip-bom-string-1.0.0.tgz#e5211e9224369fbb81d633a2f00044dc8cedad92" + integrity sha512-uCC2VHvQRYu+lMh4My/sFNmF2klFymLX1wHJeXnbEJERpV/ZsVuonzerjfrGpIGF7LBVa1O7i9kjiWvJiFck8g== + +strip-final-newline@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/strip-final-newline/-/strip-final-newline-2.0.0.tgz#89b852fb2fcbe936f6f4b3187afb0a12c1ab58ad" + integrity sha512-BrpvfNAE3dcvq7ll3xVumzjKjZQ5tI1sEUIKr3Uoks0XUl45St3FlatVqef9prk4jRDzhW6WZg+3bk93y6pLjA== + +strip-json-comments@^3.1.1: + version "3.1.1" + resolved "https://registry.yarnpkg.com/strip-json-comments/-/strip-json-comments-3.1.1.tgz#31f1281b3832630434831c310c01cccda8cbe006" + integrity sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig== + +strip-json-comments@~2.0.1: + version "2.0.1" + resolved "https://registry.yarnpkg.com/strip-json-comments/-/strip-json-comments-2.0.1.tgz#3c531942e908c2697c0ec344858c286c7ca0a60a" + integrity sha512-4gB8na07fecVVkOI6Rs4e7T6NOTki5EmL7TUduTs6bu3EdnSycntVJ4re8kgZA+wx9IueI2Y11bfbgwtzuE0KQ== + +style-to-object@^0.4.0: + version "0.4.4" + resolved "https://registry.yarnpkg.com/style-to-object/-/style-to-object-0.4.4.tgz#266e3dfd56391a7eefb7770423612d043c3f33ec" + integrity sha512-HYNoHZa2GorYNyqiCaBgsxvcJIn7OHq6inEga+E6Ke3m5JkoqpQbnFssk4jwe+K7AhGa2fcha4wSOf1Kn01dMg== + dependencies: + inline-style-parser "0.1.1" + +stylehacks@^5.1.1: + version "5.1.1" + resolved "https://registry.yarnpkg.com/stylehacks/-/stylehacks-5.1.1.tgz#7934a34eb59d7152149fa69d6e9e56f2fc34bcc9" + integrity sha512-sBpcd5Hx7G6seo7b1LkpttvTz7ikD0LlH5RmdcBNb6fFR0Fl7LQwHDFr300q4cwUqi+IYrFGmsIHieMBfnN/Bw== + dependencies: + browserslist "^4.21.4" + postcss-selector-parser "^6.0.4" + +supports-color@^5.3.0: + version "5.5.0" + resolved "https://registry.yarnpkg.com/supports-color/-/supports-color-5.5.0.tgz#e2e69a44ac8772f78a1ec0b35b689df6530efc8f" + integrity sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow== + dependencies: + has-flag "^3.0.0" + +supports-color@^7.1.0: + version "7.2.0" + resolved "https://registry.yarnpkg.com/supports-color/-/supports-color-7.2.0.tgz#1b7dcdcb32b8138801b3e478ba6a51caa89648da" + integrity sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw== + dependencies: + has-flag "^4.0.0" + +supports-color@^8.0.0: + version "8.1.1" + resolved "https://registry.yarnpkg.com/supports-color/-/supports-color-8.1.1.tgz#cd6fc17e28500cff56c1b86c0a7fd4a54a73005c" + integrity sha512-MpUEN2OodtUzxvKQl72cUF7RQ5EiHsGvSsVG0ia9c5RbWGL2CI4C7EpPS8UTBIplnlzZiNuV56w+FuNxy3ty2Q== + dependencies: + has-flag "^4.0.0" + +supports-preserve-symlinks-flag@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz#6eda4bd344a3c94aea376d4cc31bc77311039e09" + integrity sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w== + +svg-parser@^2.0.4: + version "2.0.4" + resolved "https://registry.yarnpkg.com/svg-parser/-/svg-parser-2.0.4.tgz#fdc2e29e13951736140b76cb122c8ee6630eb6b5" + integrity sha512-e4hG1hRwoOdRb37cIMSgzNsxyzKfayW6VOflrwvR+/bzrkyxY/31WkbgnQpgtrNp1SdpJvpUAGTa/ZoiPNDuRQ== + +svgo@^2.7.0, svgo@^2.8.0: + version "2.8.0" + resolved "https://registry.yarnpkg.com/svgo/-/svgo-2.8.0.tgz#4ff80cce6710dc2795f0c7c74101e6764cfccd24" + integrity sha512-+N/Q9kV1+F+UeWYoSiULYo4xYSDQlTgb+ayMobAXPwMnLvop7oxKMo9OzIrX5x3eS4L4f2UHhc9axXwY8DpChg== + dependencies: + "@trysound/sax" "0.2.0" + commander "^7.2.0" + css-select "^4.1.3" + css-tree "^1.1.3" + csso "^4.2.0" + picocolors "^1.0.0" + stable "^0.1.8" + +tapable@^1.0.0: + version "1.1.3" + resolved "https://registry.yarnpkg.com/tapable/-/tapable-1.1.3.tgz#a1fccc06b58db61fd7a45da2da44f5f3a3e67ba2" + integrity sha512-4WK/bYZmj8xLr+HUCODHGF1ZFzsYffasLUgEiMBY4fgtltdO6B4WJtlSbPaDTLpYTcGVwM2qLnFTICEcNxs3kA== + +tapable@^2.0.0, tapable@^2.1.1, tapable@^2.2.0: + version "2.2.1" + resolved "https://registry.yarnpkg.com/tapable/-/tapable-2.2.1.tgz#1967a73ef4060a82f12ab96af86d52fdb76eeca0" + integrity sha512-GNzQvQTOIP6RyTfE2Qxb8ZVlNmw0n88vp1szwWRimP02mnTsx3Wtn5qRdqY9w2XduFNUgvOwhNnQsjwCp+kqaQ== + +terser-webpack-plugin@^5.3.7, terser-webpack-plugin@^5.3.9: + version "5.3.9" + resolved "https://registry.yarnpkg.com/terser-webpack-plugin/-/terser-webpack-plugin-5.3.9.tgz#832536999c51b46d468067f9e37662a3b96adfe1" + integrity sha512-ZuXsqE07EcggTWQjXUj+Aot/OMcD0bMKGgF63f7UxYcu5/AJF53aIpK1YoP5xR9l6s/Hy2b+t1AM0bLNPRuhwA== + dependencies: + "@jridgewell/trace-mapping" "^0.3.17" + jest-worker "^27.4.5" + schema-utils "^3.1.1" + serialize-javascript "^6.0.1" + terser "^5.16.8" + +terser@^5.10.0, terser@^5.15.1, terser@^5.16.8: + version "5.24.0" + resolved "https://registry.yarnpkg.com/terser/-/terser-5.24.0.tgz#4ae50302977bca4831ccc7b4fef63a3c04228364" + integrity sha512-ZpGR4Hy3+wBEzVEnHvstMvqpD/nABNelQn/z2r0fjVWGQsN3bpOLzQlqDxmb4CDZnXq5lpjnQ+mHQLAOpfM5iw== + dependencies: + "@jridgewell/source-map" "^0.3.3" + acorn "^8.8.2" + commander "^2.20.0" + source-map-support "~0.5.20" + +text-table@^0.2.0: + version "0.2.0" + resolved "https://registry.yarnpkg.com/text-table/-/text-table-0.2.0.tgz#7f5ee823ae805207c00af2df4a84ec3fcfa570b4" + integrity sha512-N+8UisAXDGk8PFXP4HAzVR9nbfmVJ3zYLAWiTIoqC5v5isinhr+r5uaO8+7r3BMfuNIufIsA7RdpVgacC2cSpw== + +thunky@^1.0.2: + version "1.1.0" + resolved "https://registry.yarnpkg.com/thunky/-/thunky-1.1.0.tgz#5abaf714a9405db0504732bbccd2cedd9ef9537d" + integrity sha512-eHY7nBftgThBqOyHGVN+l8gF0BucP09fMo0oO/Lb0w1OF80dJv+lDVpXG60WMQvkcxAkNybKsrEIE3ZtKGmPrA== + +tiny-invariant@^1.0.2: + version "1.3.1" + resolved "https://registry.yarnpkg.com/tiny-invariant/-/tiny-invariant-1.3.1.tgz#8560808c916ef02ecfd55e66090df23a4b7aa642" + integrity sha512-AD5ih2NlSssTCwsMznbvwMZpJ1cbhkGd2uueNxzv2jDlEeZdU04JQfRnggJQ8DrcVBGjAsCKwFBbDlVNtEMlzw== + +tiny-warning@^1.0.0: + version "1.0.3" + resolved "https://registry.yarnpkg.com/tiny-warning/-/tiny-warning-1.0.3.tgz#94a30db453df4c643d0fd566060d60a875d84754" + integrity sha512-lBN9zLN/oAf68o3zNXYrdCt1kP8WsiGW8Oo2ka41b2IM5JL/S1CTyX1rW0mb/zSuJun0ZUrDxx4sqvYS2FWzPA== + +to-fast-properties@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/to-fast-properties/-/to-fast-properties-2.0.0.tgz#dc5e698cbd079265bc73e0377681a4e4e83f616e" + integrity sha512-/OaKK0xYrs3DmxRYqL/yDc+FxFUVYhDlXMhRmv3z915w2HF1tnN1omB354j8VUGO/hbRzyD6Y3sA7v7GS/ceog== + +to-regex-range@^5.0.1: + version "5.0.1" + resolved "https://registry.yarnpkg.com/to-regex-range/-/to-regex-range-5.0.1.tgz#1648c44aae7c8d988a326018ed72f5b4dd0392e4" + integrity sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ== + dependencies: + is-number "^7.0.0" + +toidentifier@1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/toidentifier/-/toidentifier-1.0.1.tgz#3be34321a88a820ed1bd80dfaa33e479fbb8dd35" + integrity sha512-o5sSPKEkg/DIQNmH43V0/uerLrpzVedkUh8tGNvaeXpfpuwjKenlSox/2O/BTlZUtEe+JG7s5YhEz608PlAHRA== + +totalist@^3.0.0: + version "3.0.1" + resolved "https://registry.yarnpkg.com/totalist/-/totalist-3.0.1.tgz#ba3a3d600c915b1a97872348f79c127475f6acf8" + integrity sha512-sf4i37nQ2LBx4m3wB74y+ubopq6W/dIzXg0FDGjsYnZHVa1Da8FH853wlL2gtUhg+xJXjfk3kUZS3BRoQeoQBQ== + +tr46@~0.0.3: + version "0.0.3" + resolved "https://registry.yarnpkg.com/tr46/-/tr46-0.0.3.tgz#8184fd347dac9cdc185992f3a6622e14b9d9ab6a" + integrity sha512-N3WMsuqV66lT30CrXNbEjx4GEwlow3v6rr4mCcv6prnfwhS01rkgyFdjPNBYd9br7LpXV1+Emh01fHnq2Gdgrw== + +trim-lines@^3.0.0: + version "3.0.1" + resolved "https://registry.yarnpkg.com/trim-lines/-/trim-lines-3.0.1.tgz#d802e332a07df861c48802c04321017b1bd87338" + integrity sha512-kRj8B+YHZCc9kQYdWfJB2/oUl9rA99qbowYYBtr4ui4mZyAQ2JpvVBd/6U2YloATfqBhBTSMhTpgBHtU0Mf3Rg== + +trough@^2.0.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/trough/-/trough-2.1.0.tgz#0f7b511a4fde65a46f18477ab38849b22c554876" + integrity sha512-AqTiAOLcj85xS7vQ8QkAV41hPDIJ71XJB4RCUrzo/1GM2CQwhkJGaf9Hgr7BOugMRpgGUrqRg/DrBDl4H40+8g== + +tslib@^2.0.3, tslib@^2.1.0, tslib@^2.6.0: + version "2.6.2" + resolved "https://registry.yarnpkg.com/tslib/-/tslib-2.6.2.tgz#703ac29425e7b37cd6fd456e92404d46d1f3e4ae" + integrity sha512-AEYxH93jGFPn/a2iVAwW87VuUIkR1FVUKB77NwMF7nBTDkDrrT/Hpt/IrCJ0QXhW27jTBDcf5ZY7w6RiqTMw2Q== + +type-fest@^1.0.1: + version "1.4.0" + resolved "https://registry.yarnpkg.com/type-fest/-/type-fest-1.4.0.tgz#e9fb813fe3bf1744ec359d55d1affefa76f14be1" + integrity sha512-yGSza74xk0UG8k+pLh5oeoYirvIiWo5t0/o3zHHAO2tRDiZcxWP7fywNlXhqb6/r6sWvwi+RsyQMWhVLe4BVuA== + +type-fest@^2.13.0, type-fest@^2.5.0: + version "2.19.0" + resolved "https://registry.yarnpkg.com/type-fest/-/type-fest-2.19.0.tgz#88068015bb33036a598b952e55e9311a60fd3a9b" + integrity sha512-RAH822pAdBgcNMAfWnCBU3CFZcfZ/i1eZjwFU/dsLKumyuuP3niueg2UAukXYF0E2AAoc82ZSSf9J0WQBinzHA== + +type-is@~1.6.18: + version "1.6.18" + resolved "https://registry.yarnpkg.com/type-is/-/type-is-1.6.18.tgz#4e552cd05df09467dcbc4ef739de89f2cf37c131" + integrity sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g== + dependencies: + media-typer "0.3.0" + mime-types "~2.1.24" + +typedarray-to-buffer@^3.1.5: + version "3.1.5" + resolved "https://registry.yarnpkg.com/typedarray-to-buffer/-/typedarray-to-buffer-3.1.5.tgz#a97ee7a9ff42691b9f783ff1bc5112fe3fca9080" + integrity sha512-zdu8XMNEDepKKR+XYOXAVPtWui0ly0NtohUscw+UmaHiAWT8hrV1rr//H6V+0DvJ3OQ19S979M0laLfX8rm82Q== + dependencies: + is-typedarray "^1.0.0" + +typedoc-plugin-markdown@^3.17.1: + version "3.17.1" + resolved "https://registry.yarnpkg.com/typedoc-plugin-markdown/-/typedoc-plugin-markdown-3.17.1.tgz#c33f42363c185adf842f4699166015f7fe0ed02b" + integrity sha512-QzdU3fj0Kzw2XSdoL15ExLASt2WPqD7FbLeaqwT70+XjKyTshBnUlQA5nNREO1C2P8Uen0CDjsBLMsCQ+zd0lw== + dependencies: + handlebars "^4.7.7" + +typedoc@^0.25.4: + version "0.25.4" + resolved "https://registry.yarnpkg.com/typedoc/-/typedoc-0.25.4.tgz#5c2c0677881f504e41985f29d9aef0dbdb6f1e6f" + integrity sha512-Du9ImmpBCw54bX275yJrxPVnjdIyJO/84co0/L9mwe0R3G4FSR6rQ09AlXVRvZEGMUg09+z/usc8mgygQ1aidA== + dependencies: + lunr "^2.3.9" + marked "^4.3.0" + minimatch "^9.0.3" + shiki "^0.14.1" + +typescript@~5.2.2: + version "5.2.2" + resolved "https://registry.yarnpkg.com/typescript/-/typescript-5.2.2.tgz#5ebb5e5a5b75f085f22bc3f8460fba308310fa78" + integrity sha512-mI4WrpHsbCIcwT9cF4FZvr80QUeKvsUsUvKDoR+X/7XHQH98xYD8YHZg7ANtz2GtZt/CBq2QJ0thkGJMHfqc1w== + +ua-parser-js@^1.0.35: + version "1.0.37" + resolved "https://registry.yarnpkg.com/ua-parser-js/-/ua-parser-js-1.0.37.tgz#b5dc7b163a5c1f0c510b08446aed4da92c46373f" + integrity sha512-bhTyI94tZofjo+Dn8SN6Zv8nBDvyXTymAdM3LDI/0IboIUwTu1rEhW7v2TfiVsoYWgkQ4kOVqnI8APUFbIQIFQ== + +uglify-js@^3.1.4: + version "3.17.4" + resolved "https://registry.yarnpkg.com/uglify-js/-/uglify-js-3.17.4.tgz#61678cf5fa3f5b7eb789bb345df29afb8257c22c" + integrity sha512-T9q82TJI9e/C1TAxYvfb16xO120tMVFZrGA3f9/P4424DNu6ypK103y0GPFVa17yotwSyZW5iYXgjYHkGrJW/g== + +undici-types@~5.26.4: + version "5.26.5" + resolved "https://registry.yarnpkg.com/undici-types/-/undici-types-5.26.5.tgz#bcd539893d00b56e964fd2657a4866b221a65617" + integrity sha512-JlCMO+ehdEIKqlFxk6IfVoAUVmgz7cU7zD/h9XZ0qzeosSHmUJVOzSQvvYSYWXkFXC+IfLKSIffhv0sVZup6pA== + +unicode-canonical-property-names-ecmascript@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/unicode-canonical-property-names-ecmascript/-/unicode-canonical-property-names-ecmascript-2.0.0.tgz#301acdc525631670d39f6146e0e77ff6bbdebddc" + integrity sha512-yY5PpDlfVIU5+y/BSCxAJRBIS1Zc2dDG3Ujq+sR0U+JjUevW2JhocOF+soROYDSaAezOzOKuyyixhD6mBknSmQ== + +unicode-emoji-modifier-base@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/unicode-emoji-modifier-base/-/unicode-emoji-modifier-base-1.0.0.tgz#dbbd5b54ba30f287e2a8d5a249da6c0cef369459" + integrity sha512-yLSH4py7oFH3oG/9K+XWrz1pSi3dfUrWEnInbxMfArOfc1+33BlGPQtLsOYwvdMy11AwUBetYuaRxSPqgkq+8g== + +unicode-match-property-ecmascript@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/unicode-match-property-ecmascript/-/unicode-match-property-ecmascript-2.0.0.tgz#54fd16e0ecb167cf04cf1f756bdcc92eba7976c3" + integrity sha512-5kaZCrbp5mmbz5ulBkDkbY0SsPOjKqVS35VpL9ulMPfSl0J0Xsm+9Evphv9CoIZFwre7aJoa94AY6seMKGVN5Q== + dependencies: + unicode-canonical-property-names-ecmascript "^2.0.0" + unicode-property-aliases-ecmascript "^2.0.0" + +unicode-match-property-value-ecmascript@^2.1.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/unicode-match-property-value-ecmascript/-/unicode-match-property-value-ecmascript-2.1.0.tgz#cb5fffdcd16a05124f5a4b0bf7c3770208acbbe0" + integrity sha512-qxkjQt6qjg/mYscYMC0XKRn3Rh0wFPlfxB0xkt9CfyTvpX1Ra0+rAmdX2QyAobptSEvuy4RtpPRui6XkV+8wjA== + +unicode-property-aliases-ecmascript@^2.0.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/unicode-property-aliases-ecmascript/-/unicode-property-aliases-ecmascript-2.1.0.tgz#43d41e3be698bd493ef911077c9b131f827e8ccd" + integrity sha512-6t3foTQI9qne+OZoVQB/8x8rk2k1eVy1gRXhV3oFQ5T6R1dqQ1xtin3XqSlx3+ATBkliTaR/hHyJBm+LVPNM8w== + +unified@^11.0.0, unified@^11.0.3, unified@^11.0.4: + version "11.0.4" + resolved "https://registry.yarnpkg.com/unified/-/unified-11.0.4.tgz#f4be0ac0fe4c88cb873687c07c64c49ed5969015" + integrity sha512-apMPnyLjAX+ty4OrNap7yumyVAMlKx5IWU2wlzzUdYJO9A8f1p9m/gywF/GM2ZDFcjQPrx59Mc90KwmxsoklxQ== + dependencies: + "@types/unist" "^3.0.0" + bail "^2.0.0" + devlop "^1.0.0" + extend "^3.0.0" + is-plain-obj "^4.0.0" + trough "^2.0.0" + vfile "^6.0.0" + +unique-string@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/unique-string/-/unique-string-3.0.0.tgz#84a1c377aff5fd7a8bc6b55d8244b2bd90d75b9a" + integrity sha512-VGXBUVwxKMBUznyffQweQABPRRW1vHZAbadFZud4pLFAqRGvv/96vafgjWFqzourzr8YonlQiPgH0YCJfawoGQ== + dependencies: + crypto-random-string "^4.0.0" + +unist-util-is@^6.0.0: + version "6.0.0" + resolved "https://registry.yarnpkg.com/unist-util-is/-/unist-util-is-6.0.0.tgz#b775956486aff107a9ded971d996c173374be424" + integrity sha512-2qCTHimwdxLfz+YzdGfkqNlH0tLi9xjTnHddPmJwtIG9MGsdbutfTc4P+haPD7l7Cjxf/WZj+we5qfVPvvxfYw== + dependencies: + "@types/unist" "^3.0.0" + +unist-util-position-from-estree@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/unist-util-position-from-estree/-/unist-util-position-from-estree-2.0.0.tgz#d94da4df596529d1faa3de506202f0c9a23f2200" + integrity sha512-KaFVRjoqLyF6YXCbVLNad/eS4+OfPQQn2yOd7zF/h5T/CSL2v8NpN6a5TPvtbXthAGw5nG+PuTtq+DdIZr+cRQ== + dependencies: + "@types/unist" "^3.0.0" + +unist-util-position@^5.0.0: + version "5.0.0" + resolved "https://registry.yarnpkg.com/unist-util-position/-/unist-util-position-5.0.0.tgz#678f20ab5ca1207a97d7ea8a388373c9cf896be4" + integrity sha512-fucsC7HjXvkB5R3kTCO7kUjRdrS0BJt3M/FPxmHMBOm8JQi2BsHAHFsy27E0EolP8rp0NzXsJ+jNPyDWvOJZPA== + dependencies: + "@types/unist" "^3.0.0" + +unist-util-remove-position@^5.0.0: + version "5.0.0" + resolved "https://registry.yarnpkg.com/unist-util-remove-position/-/unist-util-remove-position-5.0.0.tgz#fea68a25658409c9460408bc6b4991b965b52163" + integrity sha512-Hp5Kh3wLxv0PHj9m2yZhhLt58KzPtEYKQQ4yxfYFEO7EvHwzyDYnduhHnY1mDxoqr7VUwVuHXk9RXKIiYS1N8Q== + dependencies: + "@types/unist" "^3.0.0" + unist-util-visit "^5.0.0" + +unist-util-stringify-position@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/unist-util-stringify-position/-/unist-util-stringify-position-4.0.0.tgz#449c6e21a880e0855bf5aabadeb3a740314abac2" + integrity sha512-0ASV06AAoKCDkS2+xw5RXJywruurpbC4JZSm7nr7MOt1ojAzvyyaO+UxZf18j8FCF6kmzCZKcAgN/yu2gm2XgQ== + dependencies: + "@types/unist" "^3.0.0" + +unist-util-visit-parents@^6.0.0: + version "6.0.1" + resolved "https://registry.yarnpkg.com/unist-util-visit-parents/-/unist-util-visit-parents-6.0.1.tgz#4d5f85755c3b8f0dc69e21eca5d6d82d22162815" + integrity sha512-L/PqWzfTP9lzzEa6CKs0k2nARxTdZduw3zyh8d2NVBnsyvHjSX4TWse388YrrQKbvI8w20fGjGlhgT96WwKykw== + dependencies: + "@types/unist" "^3.0.0" + unist-util-is "^6.0.0" + +unist-util-visit@^5.0.0: + version "5.0.0" + resolved "https://registry.yarnpkg.com/unist-util-visit/-/unist-util-visit-5.0.0.tgz#a7de1f31f72ffd3519ea71814cccf5fd6a9217d6" + integrity sha512-MR04uvD+07cwl/yhVuVWAtw+3GOR/knlL55Nd/wAdblk27GCVt3lqpTivy/tkJcZoNPzTwS1Y+KMojlLDhoTzg== + dependencies: + "@types/unist" "^3.0.0" + unist-util-is "^6.0.0" + unist-util-visit-parents "^6.0.0" + +universalify@^2.0.0: + version "2.0.1" + resolved "https://registry.yarnpkg.com/universalify/-/universalify-2.0.1.tgz#168efc2180964e6386d061e094df61afe239b18d" + integrity sha512-gptHNQghINnc/vTGIk0SOFGFNXw7JVrlRUtConJRlvaw6DuX0wO5Jeko9sWrMBhh+PsYAZ7oXAiOnf/UKogyiw== + +unpipe@1.0.0, unpipe@~1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/unpipe/-/unpipe-1.0.0.tgz#b2bf4ee8514aae6165b4817829d21b2ef49904ec" + integrity sha512-pjy2bYhSsufwWlKwPc+l3cN7+wuJlK6uz0YdJEOlQDbl6jo/YlPi4mb8agUkVC8BF7V8NuzeyPNqRksA3hztKQ== + +update-browserslist-db@^1.0.13: + version "1.0.13" + resolved "https://registry.yarnpkg.com/update-browserslist-db/-/update-browserslist-db-1.0.13.tgz#3c5e4f5c083661bd38ef64b6328c26ed6c8248c4" + integrity sha512-xebP81SNcPuNpPP3uzeW1NYXxI3rxyJzF3pD6sH4jE7o/IX+WtSpwnVU+qIsDPyk0d3hmFQ7mjqc6AtV604hbg== + dependencies: + escalade "^3.1.1" + picocolors "^1.0.0" + +update-notifier@^6.0.2: + version "6.0.2" + resolved "https://registry.yarnpkg.com/update-notifier/-/update-notifier-6.0.2.tgz#a6990253dfe6d5a02bd04fbb6a61543f55026b60" + integrity sha512-EDxhTEVPZZRLWYcJ4ZXjGFN0oP7qYvbXWzEgRm/Yql4dHX5wDbvh89YHP6PK1lzZJYrMtXUuZZz8XGK+U6U1og== + dependencies: + boxen "^7.0.0" + chalk "^5.0.1" + configstore "^6.0.0" + has-yarn "^3.0.0" + import-lazy "^4.0.0" + is-ci "^3.0.1" + is-installed-globally "^0.4.0" + is-npm "^6.0.0" + is-yarn-global "^0.4.0" + latest-version "^7.0.0" + pupa "^3.1.0" + semver "^7.3.7" + semver-diff "^4.0.0" + xdg-basedir "^5.1.0" + +uri-js@^4.2.2: + version "4.4.1" + resolved "https://registry.yarnpkg.com/uri-js/-/uri-js-4.4.1.tgz#9b1a52595225859e55f669d928f88c6c57f2a77e" + integrity sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg== + dependencies: + punycode "^2.1.0" + +url-loader@^4.1.1: + version "4.1.1" + resolved "https://registry.yarnpkg.com/url-loader/-/url-loader-4.1.1.tgz#28505e905cae158cf07c92ca622d7f237e70a4e2" + integrity sha512-3BTV812+AVHHOJQO8O5MkWgZ5aosP7GnROJwvzLS9hWDj00lZ6Z0wNak423Lp9PBZN05N+Jk/N5Si8jRAlGyWA== + dependencies: + loader-utils "^2.0.0" + mime-types "^2.1.27" + schema-utils "^3.0.0" + +use-composed-ref@^1.3.0: + version "1.3.0" + resolved "https://registry.yarnpkg.com/use-composed-ref/-/use-composed-ref-1.3.0.tgz#3d8104db34b7b264030a9d916c5e94fbe280dbda" + integrity sha512-GLMG0Jc/jiKov/3Ulid1wbv3r54K9HlMW29IWcDFPEqFkSO2nS0MuefWgMJpeHQ9YJeXDL3ZUF+P3jdXlZX/cQ== + +use-isomorphic-layout-effect@^1.1.1: + version "1.1.2" + resolved "https://registry.yarnpkg.com/use-isomorphic-layout-effect/-/use-isomorphic-layout-effect-1.1.2.tgz#497cefb13d863d687b08477d9e5a164ad8c1a6fb" + integrity sha512-49L8yCO3iGT/ZF9QttjwLF/ZD9Iwto5LnH5LmEdk/6cFmXddqi2ulF0edxTwjj+7mqvpVVGQWvbXZdn32wRSHA== + +use-latest@^1.2.1: + version "1.2.1" + resolved "https://registry.yarnpkg.com/use-latest/-/use-latest-1.2.1.tgz#d13dfb4b08c28e3e33991546a2cee53e14038cf2" + integrity sha512-xA+AVm/Wlg3e2P/JiItTziwS7FK92LWrDB0p+hgXloIMuVCeJJ8v6f0eeHyPZaJrM+usM1FkFfbNCrJGs8A/zw== + dependencies: + use-isomorphic-layout-effect "^1.1.1" + +util-deprecate@^1.0.1, util-deprecate@^1.0.2, 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== + +utila@~0.4: + version "0.4.0" + resolved "https://registry.yarnpkg.com/utila/-/utila-0.4.0.tgz#8a16a05d445657a3aea5eecc5b12a4fa5379772c" + integrity sha512-Z0DbgELS9/L/75wZbro8xAnT50pBVFQZ+hUEueGDU5FN51YSCYM+jdxsfCiHjwNP/4LCDD0i/graKpeBnOXKRA== + +utility-types@^3.10.0: + version "3.10.0" + resolved "https://registry.yarnpkg.com/utility-types/-/utility-types-3.10.0.tgz#ea4148f9a741015f05ed74fd615e1d20e6bed82b" + integrity sha512-O11mqxmi7wMKCo6HKFt5AhO4BwY3VV68YU07tgxfz8zJTIxr4BpsezN49Ffwy9j3ZpwwJp4fkRwjRzq3uWE6Rg== + +utils-merge@1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/utils-merge/-/utils-merge-1.0.1.tgz#9f95710f50a267947b2ccc124741c1028427e713" + integrity sha512-pMZTvIkT1d+TFGvDOqodOclx0QWkkgi6Tdoa8gC8ffGAAqz9pzPTZWAybbsHHoED/ztMtkv/VoYTYyShUn81hA== + +uuid@^8.3.2: + version "8.3.2" + resolved "https://registry.yarnpkg.com/uuid/-/uuid-8.3.2.tgz#80d5b5ced271bb9af6c445f21a1a04c606cefbe2" + integrity sha512-+NYs2QeMWy+GWFOEm9xnn6HCDp0l7QBD7ml8zLUmJ+93Q5NF0NocErnwkTkXVFNiX3/fpC6afS8Dhb/gz7R7eg== + +value-equal@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/value-equal/-/value-equal-1.0.1.tgz#1e0b794c734c5c0cade179c437d356d931a34d6c" + integrity sha512-NOJ6JZCAWr0zlxZt+xqCHNTEKOsrks2HQd4MqhP1qy4z1SkbEP467eNx6TgDKXMvUOb+OENfJCZwM+16n7fRfw== + +vary@~1.1.2: + version "1.1.2" + resolved "https://registry.yarnpkg.com/vary/-/vary-1.1.2.tgz#2299f02c6ded30d4a5961b0b9f74524a18f634fc" + integrity sha512-BNGbWLfd0eUPabhkXUVm0j8uuvREyTh5ovRa/dyow/BqAbZJyC+5fU+IzQOzmAKzYqYRAISoRhdQr3eIZ/PXqg== + +vfile-location@^5.0.0: + version "5.0.2" + resolved "https://registry.yarnpkg.com/vfile-location/-/vfile-location-5.0.2.tgz#220d9ca1ab6f8b2504a4db398f7ebc149f9cb464" + integrity sha512-NXPYyxyBSH7zB5U6+3uDdd6Nybz6o6/od9rk8bp9H8GR3L+cm/fC0uUTbqBmUTnMCUDslAGBOIKNfvvb+gGlDg== + dependencies: + "@types/unist" "^3.0.0" + vfile "^6.0.0" + +vfile-message@^4.0.0: + version "4.0.2" + resolved "https://registry.yarnpkg.com/vfile-message/-/vfile-message-4.0.2.tgz#c883c9f677c72c166362fd635f21fc165a7d1181" + integrity sha512-jRDZ1IMLttGj41KcZvlrYAaI3CfqpLpfpf+Mfig13viT6NKvRzWZ+lXz0Y5D60w6uJIBAOGq9mSHf0gktF0duw== + dependencies: + "@types/unist" "^3.0.0" + unist-util-stringify-position "^4.0.0" + +vfile@^6.0.0, vfile@^6.0.1: + version "6.0.1" + resolved "https://registry.yarnpkg.com/vfile/-/vfile-6.0.1.tgz#1e8327f41eac91947d4fe9d237a2dd9209762536" + integrity sha512-1bYqc7pt6NIADBJ98UiG0Bn/CHIVOoZ/IyEkqIruLg0mE1BKzkOXY2D6CSqQIcKqgadppE5lrxgWXJmXd7zZJw== + dependencies: + "@types/unist" "^3.0.0" + unist-util-stringify-position "^4.0.0" + vfile-message "^4.0.0" + +vscode-oniguruma@^1.7.0: + version "1.7.0" + resolved "https://registry.yarnpkg.com/vscode-oniguruma/-/vscode-oniguruma-1.7.0.tgz#439bfad8fe71abd7798338d1cd3dc53a8beea94b" + integrity sha512-L9WMGRfrjOhgHSdOYgCt/yRMsXzLDJSL7BPrOZt73gU0iWO4mpqzqQzOz5srxqTvMBaR0XZTSrVWo4j55Rc6cA== + +vscode-textmate@^8.0.0: + version "8.0.0" + resolved "https://registry.yarnpkg.com/vscode-textmate/-/vscode-textmate-8.0.0.tgz#2c7a3b1163ef0441097e0b5d6389cd5504b59e5d" + integrity sha512-AFbieoL7a5LMqcnOF04ji+rpXadgOXnZsxQr//r83kLPr7biP7am3g9zbaZIaBGwBRWeSvoMD4mgPdX3e4NWBg== + +wait-on@^7.0.1: + version "7.2.0" + resolved "https://registry.yarnpkg.com/wait-on/-/wait-on-7.2.0.tgz#d76b20ed3fc1e2bebc051fae5c1ff93be7892928" + integrity sha512-wCQcHkRazgjG5XoAq9jbTMLpNIjoSlZslrJ2+N9MxDsGEv1HnFoVjOCexL0ESva7Y9cu350j+DWADdk54s4AFQ== + dependencies: + axios "^1.6.1" + joi "^17.11.0" + lodash "^4.17.21" + minimist "^1.2.8" + rxjs "^7.8.1" + +watchpack@^2.4.0: + version "2.4.0" + resolved "https://registry.yarnpkg.com/watchpack/-/watchpack-2.4.0.tgz#fa33032374962c78113f93c7f2fb4c54c9862a5d" + integrity sha512-Lcvm7MGST/4fup+ifyKi2hjyIAwcdI4HRgtvTpIUxBRhB+RFtUh8XtDOxUfctVCnhVi+QQj49i91OyvzkJl6cg== + dependencies: + glob-to-regexp "^0.4.1" + graceful-fs "^4.1.2" + +wbuf@^1.1.0, wbuf@^1.7.3: + version "1.7.3" + resolved "https://registry.yarnpkg.com/wbuf/-/wbuf-1.7.3.tgz#c1d8d149316d3ea852848895cb6a0bfe887b87df" + integrity sha512-O84QOnr0icsbFGLS0O3bI5FswxzRr8/gHwWkDlQFskhSPryQXvrTMxjxGP4+iWYoauLoBvfDpkrOauZ+0iZpDA== + dependencies: + minimalistic-assert "^1.0.0" + +web-namespaces@^2.0.0: + version "2.0.1" + resolved "https://registry.yarnpkg.com/web-namespaces/-/web-namespaces-2.0.1.tgz#1010ff7c650eccb2592cebeeaf9a1b253fd40692" + integrity sha512-bKr1DkiNa2krS7qxNtdrtHAmzuYGFQLiQ13TsorsdT6ULTkPLKuu5+GsFpDlg6JFjUTwX2DyhMPG2be8uPrqsQ== + +webidl-conversions@^3.0.0: + version "3.0.1" + resolved "https://registry.yarnpkg.com/webidl-conversions/-/webidl-conversions-3.0.1.tgz#24534275e2a7bc6be7bc86611cc16ae0a5654871" + integrity sha512-2JAn3z8AR6rjK8Sm8orRC0h/bcl/DqL7tRPdGZ4I1CjdF+EaMLmYxBHyXuKL849eucPFhvBoxMsflfOb8kxaeQ== + +webpack-bundle-analyzer@^4.9.0: + version "4.10.1" + resolved "https://registry.yarnpkg.com/webpack-bundle-analyzer/-/webpack-bundle-analyzer-4.10.1.tgz#84b7473b630a7b8c21c741f81d8fe4593208b454" + integrity sha512-s3P7pgexgT/HTUSYgxJyn28A+99mmLq4HsJepMPzu0R8ImJc52QNqaFYW1Z2z2uIb1/J3eYgaAWVpaC+v/1aAQ== + dependencies: + "@discoveryjs/json-ext" "0.5.7" + acorn "^8.0.4" + acorn-walk "^8.0.0" + commander "^7.2.0" + debounce "^1.2.1" + escape-string-regexp "^4.0.0" + gzip-size "^6.0.0" + html-escaper "^2.0.2" + is-plain-object "^5.0.0" + opener "^1.5.2" + picocolors "^1.0.0" + sirv "^2.0.3" + ws "^7.3.1" + +webpack-dev-middleware@^5.3.1: + version "5.3.3" + resolved "https://registry.yarnpkg.com/webpack-dev-middleware/-/webpack-dev-middleware-5.3.3.tgz#efae67c2793908e7311f1d9b06f2a08dcc97e51f" + integrity sha512-hj5CYrY0bZLB+eTO+x/j67Pkrquiy7kWepMHmUMoPsmcUaeEnQJqFzHJOyxgWlq746/wUuA64p9ta34Kyb01pA== + dependencies: + colorette "^2.0.10" + memfs "^3.4.3" + mime-types "^2.1.31" + range-parser "^1.2.1" + schema-utils "^4.0.0" + +webpack-dev-server@^4.15.1: + version "4.15.1" + resolved "https://registry.yarnpkg.com/webpack-dev-server/-/webpack-dev-server-4.15.1.tgz#8944b29c12760b3a45bdaa70799b17cb91b03df7" + integrity sha512-5hbAst3h3C3L8w6W4P96L5vaV0PxSmJhxZvWKYIdgxOQm8pNZ5dEOmmSLBVpP85ReeyRt6AS1QJNyo/oFFPeVA== + dependencies: + "@types/bonjour" "^3.5.9" + "@types/connect-history-api-fallback" "^1.3.5" + "@types/express" "^4.17.13" + "@types/serve-index" "^1.9.1" + "@types/serve-static" "^1.13.10" + "@types/sockjs" "^0.3.33" + "@types/ws" "^8.5.5" + ansi-html-community "^0.0.8" + bonjour-service "^1.0.11" + chokidar "^3.5.3" + colorette "^2.0.10" + compression "^1.7.4" + connect-history-api-fallback "^2.0.0" + default-gateway "^6.0.3" + express "^4.17.3" + graceful-fs "^4.2.6" + html-entities "^2.3.2" + http-proxy-middleware "^2.0.3" + ipaddr.js "^2.0.1" + launch-editor "^2.6.0" + open "^8.0.9" + p-retry "^4.5.0" + rimraf "^3.0.2" + schema-utils "^4.0.0" + selfsigned "^2.1.1" + serve-index "^1.9.1" + sockjs "^0.3.24" + spdy "^4.0.2" + webpack-dev-middleware "^5.3.1" + ws "^8.13.0" + +webpack-merge@^5.9.0: + version "5.10.0" + resolved "https://registry.yarnpkg.com/webpack-merge/-/webpack-merge-5.10.0.tgz#a3ad5d773241e9c682803abf628d4cd62b8a4177" + integrity sha512-+4zXKdx7UnO+1jaN4l2lHVD+mFvnlZQP/6ljaJVb4SZiwIKeUnrT5l0gkT8z+n4hKpC+jpOv6O9R+gLtag7pSA== + dependencies: + clone-deep "^4.0.1" + flat "^5.0.2" + wildcard "^2.0.0" + +webpack-sources@^3.2.2, webpack-sources@^3.2.3: + version "3.2.3" + resolved "https://registry.yarnpkg.com/webpack-sources/-/webpack-sources-3.2.3.tgz#2d4daab8451fd4b240cc27055ff6a0c2ccea0cde" + integrity sha512-/DyMEOrDgLKKIG0fmvtz+4dUX/3Ghozwgm6iPp8KRhvn+eQf9+Q7GWxVNMk3+uCPWfdXYC4ExGBckIXdFEfH1w== + +webpack@^5.88.1: + version "5.89.0" + resolved "https://registry.yarnpkg.com/webpack/-/webpack-5.89.0.tgz#56b8bf9a34356e93a6625770006490bf3a7f32dc" + integrity sha512-qyfIC10pOr70V+jkmud8tMfajraGCZMBWJtrmuBymQKCrLTRejBI8STDp1MCyZu/QTdZSeacCQYpYNQVOzX5kw== + dependencies: + "@types/eslint-scope" "^3.7.3" + "@types/estree" "^1.0.0" + "@webassemblyjs/ast" "^1.11.5" + "@webassemblyjs/wasm-edit" "^1.11.5" + "@webassemblyjs/wasm-parser" "^1.11.5" + acorn "^8.7.1" + acorn-import-assertions "^1.9.0" + browserslist "^4.14.5" + chrome-trace-event "^1.0.2" + enhanced-resolve "^5.15.0" + es-module-lexer "^1.2.1" + eslint-scope "5.1.1" + events "^3.2.0" + glob-to-regexp "^0.4.1" + graceful-fs "^4.2.9" + json-parse-even-better-errors "^2.3.1" + loader-runner "^4.2.0" + mime-types "^2.1.27" + neo-async "^2.6.2" + schema-utils "^3.2.0" + tapable "^2.1.1" + terser-webpack-plugin "^5.3.7" + watchpack "^2.4.0" + webpack-sources "^3.2.3" + +webpackbar@^5.0.2: + version "5.0.2" + resolved "https://registry.yarnpkg.com/webpackbar/-/webpackbar-5.0.2.tgz#d3dd466211c73852741dfc842b7556dcbc2b0570" + integrity sha512-BmFJo7veBDgQzfWXl/wwYXr/VFus0614qZ8i9znqcl9fnEdiVkdbi0TedLQ6xAK92HZHDJ0QmyQ0fmuZPAgCYQ== + dependencies: + chalk "^4.1.0" + consola "^2.15.3" + pretty-time "^1.1.0" + std-env "^3.0.1" + +websocket-driver@>=0.5.1, websocket-driver@^0.7.4: + version "0.7.4" + resolved "https://registry.yarnpkg.com/websocket-driver/-/websocket-driver-0.7.4.tgz#89ad5295bbf64b480abcba31e4953aca706f5760" + integrity sha512-b17KeDIQVjvb0ssuSDF2cYXSg2iztliJ4B9WdsuB6J952qCPKmnVq4DyW5motImXHDC1cBT/1UezrJVsKw5zjg== + dependencies: + http-parser-js ">=0.5.1" + safe-buffer ">=5.1.0" + websocket-extensions ">=0.1.1" + +websocket-extensions@>=0.1.1: + version "0.1.4" + resolved "https://registry.yarnpkg.com/websocket-extensions/-/websocket-extensions-0.1.4.tgz#7f8473bc839dfd87608adb95d7eb075211578a42" + integrity sha512-OqedPIGOfsDlo31UNwYbCFMSaO9m9G/0faIHj5/dZFDMFqPTcx6UwqyOy3COEaEOg/9VsGIpdqn62W5KhoKSpg== + +whatwg-url@^5.0.0: + version "5.0.0" + resolved "https://registry.yarnpkg.com/whatwg-url/-/whatwg-url-5.0.0.tgz#966454e8765462e37644d3626f6742ce8b70965d" + integrity sha512-saE57nupxk6v3HY35+jzBwYa0rKSy0XR8JSxZPwgLr7ys0IBzhGviA1/TUGJLmSVqs8pb9AnvICXEuOHLprYTw== + dependencies: + tr46 "~0.0.3" + webidl-conversions "^3.0.0" + +which@^1.3.1: + version "1.3.1" + resolved "https://registry.yarnpkg.com/which/-/which-1.3.1.tgz#a45043d54f5805316da8d62f9f50918d3da70b0a" + integrity sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ== + dependencies: + isexe "^2.0.0" + +which@^2.0.1: + version "2.0.2" + resolved "https://registry.yarnpkg.com/which/-/which-2.0.2.tgz#7c6a8dd0a636a0327e10b59c9286eee93f3f51b1" + integrity sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA== + dependencies: + isexe "^2.0.0" + +widest-line@^4.0.1: + version "4.0.1" + resolved "https://registry.yarnpkg.com/widest-line/-/widest-line-4.0.1.tgz#a0fc673aaba1ea6f0a0d35b3c2795c9a9cc2ebf2" + integrity sha512-o0cyEG0e8GPzT4iGHphIOh0cJOV8fivsXxddQasHPHfoZf1ZexrfeA21w2NaEN1RHE+fXlfISmOE8R9N3u3Qig== + dependencies: + string-width "^5.0.1" + +wildcard@^2.0.0: + version "2.0.1" + resolved "https://registry.yarnpkg.com/wildcard/-/wildcard-2.0.1.tgz#5ab10d02487198954836b6349f74fff961e10f67" + integrity sha512-CC1bOL87PIWSBhDcTrdeLo6eGT7mCFtrg0uIJtqJUFyK+eJnzl8A1niH56uu7KMa5XFrtiV+AQuHO3n7DsHnLQ== + +wordwrap@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/wordwrap/-/wordwrap-1.0.0.tgz#27584810891456a4171c8d0226441ade90cbcaeb" + integrity sha512-gvVzJFlPycKc5dZN4yPkP8w7Dc37BtP1yczEneOb4uq34pXZcvrtRTmWV8W+Ume+XCxKgbjM+nevkyFPMybd4Q== + +wrap-ansi@^8.0.1, wrap-ansi@^8.1.0: + version "8.1.0" + resolved "https://registry.yarnpkg.com/wrap-ansi/-/wrap-ansi-8.1.0.tgz#56dc22368ee570face1b49819975d9b9a5ead214" + integrity sha512-si7QWI6zUMq56bESFvagtmzMdGOtoxfR+Sez11Mobfc7tm+VkUckk9bW2UeffTGVUbOksxmSw0AA2gs8g71NCQ== + dependencies: + ansi-styles "^6.1.0" + string-width "^5.0.1" + strip-ansi "^7.0.1" + +wrappy@1: + version "1.0.2" + resolved "https://registry.yarnpkg.com/wrappy/-/wrappy-1.0.2.tgz#b5243d8f3ec1aa35f1364605bc0d1036e30ab69f" + integrity sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ== + +write-file-atomic@^3.0.3: + version "3.0.3" + resolved "https://registry.yarnpkg.com/write-file-atomic/-/write-file-atomic-3.0.3.tgz#56bd5c5a5c70481cd19c571bd39ab965a5de56e8" + integrity sha512-AvHcyZ5JnSfq3ioSyjrBkH9yW4m7Ayk8/9My/DD9onKeu/94fwrMocemO2QAJFAlnnDN+ZDS+ZjAR5ua1/PV/Q== + dependencies: + imurmurhash "^0.1.4" + is-typedarray "^1.0.0" + signal-exit "^3.0.2" + typedarray-to-buffer "^3.1.5" + +ws@^7.3.1: + version "7.5.9" + resolved "https://registry.yarnpkg.com/ws/-/ws-7.5.9.tgz#54fa7db29f4c7cec68b1ddd3a89de099942bb591" + integrity sha512-F+P9Jil7UiSKSkppIiD94dN07AwvFixvLIj1Og1Rl9GGMuNipJnV9JzjD6XuqmAeiswGvUmNLjr5cFuXwNS77Q== + +ws@^8.13.0: + version "8.14.2" + resolved "https://registry.yarnpkg.com/ws/-/ws-8.14.2.tgz#6c249a806eb2db7a20d26d51e7709eab7b2e6c7f" + integrity sha512-wEBG1ftX4jcglPxgFCMJmZ2PLtSbJ2Peg6TmpJFTbe9GZYOQCDPdMYu/Tm0/bGZkw8paZnJY45J4K2PZrLYq8g== + +xdg-basedir@^5.0.1, xdg-basedir@^5.1.0: + version "5.1.0" + resolved "https://registry.yarnpkg.com/xdg-basedir/-/xdg-basedir-5.1.0.tgz#1efba19425e73be1bc6f2a6ceb52a3d2c884c0c9" + integrity sha512-GCPAHLvrIH13+c0SuacwvRYj2SxJXQ4kaVTT5xgL3kPrz56XxkF21IGhjSE1+W0aw7gpBWRGXLCPnPby6lSpmQ== + +xml-js@^1.6.11: + version "1.6.11" + resolved "https://registry.yarnpkg.com/xml-js/-/xml-js-1.6.11.tgz#927d2f6947f7f1c19a316dd8eea3614e8b18f8e9" + integrity sha512-7rVi2KMfwfWFl+GpPg6m80IVMWXLRjO+PxTq7V2CDhoGak0wzYzFgUY2m4XJ47OGdXd8eLE8EmwfAmdjw7lC1g== + dependencies: + sax "^1.2.4" + +yallist@^3.0.2: + version "3.1.1" + resolved "https://registry.yarnpkg.com/yallist/-/yallist-3.1.1.tgz#dbb7daf9bfd8bac9ab45ebf602b8cbad0d5d08fd" + integrity sha512-a4UGQaWPH59mOXUYnAG2ewncQS4i4F43Tv3JoAM+s2VDAmS9NsK8GpDMLrCHPksFT7h3K6TOoUNn2pb7RoXx4g== + +yallist@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/yallist/-/yallist-4.0.0.tgz#9bb92790d9c0effec63be73519e11a35019a3a72" + integrity sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A== + +yaml@^1.10.0, yaml@^1.10.2, yaml@^1.7.2: + version "1.10.2" + resolved "https://registry.yarnpkg.com/yaml/-/yaml-1.10.2.tgz#2301c5ffbf12b467de8da2333a459e29e7920e4b" + integrity sha512-r3vXyErRCYJ7wg28yvBY5VSoAF8ZvlcW9/BwUzEtUsjvX/DKs24dIkuwjtuprwJJHsbyUbLApepYTR1BN4uHrg== + +yocto-queue@^0.1.0: + version "0.1.0" + resolved "https://registry.yarnpkg.com/yocto-queue/-/yocto-queue-0.1.0.tgz#0294eb3dee05028d31ee1a5fa2c556a6aaf10a1b" + integrity sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q== + +yocto-queue@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/yocto-queue/-/yocto-queue-1.0.0.tgz#7f816433fb2cbc511ec8bf7d263c3b58a1a3c251" + integrity sha512-9bnSc/HEW2uRy67wc+T8UwauLuPJVn28jb+GtJY16iiKWyvmYJRXVT4UamsAEGQfPohgr2q4Tq0sQbQlxTfi1g== + +zwitch@^2.0.0: + version "2.0.4" + resolved "https://registry.yarnpkg.com/zwitch/-/zwitch-2.0.4.tgz#c827d4b0acb76fc3e685a4c6ec2902d51070e9d7" + integrity sha512-bXE4cR/kVZhKZX/RjPEflHaKVhUVl85noU3v6b8apfQEc1x4A+zBxjZ4lN8LqGd6WZ3dl98pY4o717VFmoPp+A== diff --git a/package.json b/package.json index 785db6ce..4ccfc0b5 100644 --- a/package.json +++ b/package.json @@ -6,14 +6,14 @@ "scripts": { "clean:packages": "lerna run clean", "build:packages": "lerna run build", - "docs": "typedoc", "watch:packages": "yarn workspace @journeyapps/powersync-sdk-react-native watch", "release": "yarn build:packages && yarn changeset publish" }, "workspaces": { "packages": [ "apps/*", - "packages/*" + "packages/*", + "docs/*" ], "nohoist": [ "**/@rneui/**", diff --git a/packages/powersync-attachments/package.json b/packages/powersync-attachments/package.json index 7ddbf20c..cec9f681 100644 --- a/packages/powersync-attachments/package.json +++ b/packages/powersync-attachments/package.json @@ -13,7 +13,6 @@ ], "scripts": { "build": "tsc -b", - "docs": "typedoc --out docs", "clean": "rm -rf lib tsconfig.tsbuildinfo", "watch": "tsc -b -w" }, diff --git a/packages/powersync-react/package.json b/packages/powersync-react/package.json index bd74ad81..9a10b24d 100644 --- a/packages/powersync-react/package.json +++ b/packages/powersync-react/package.json @@ -13,7 +13,6 @@ ], "scripts": { "build": "tsc -b", - "docs": "typedoc --out docs", "clean": "rm -rf lib tsconfig.tsbuildinfo", "watch": "tsc -b -w" }, diff --git a/packages/powersync-sdk-common/package.json b/packages/powersync-sdk-common/package.json index 7895c538..3b3f065f 100644 --- a/packages/powersync-sdk-common/package.json +++ b/packages/powersync-sdk-common/package.json @@ -23,7 +23,6 @@ "homepage": "https://docs.powersync.co/resources/api-reference", "scripts": { "build": "tsc -b", - "docs": "typedoc --out docs", "clean": "rm -rf lib tsconfig.tsbuildinfo" }, "devDependencies": { diff --git a/packages/powersync-sdk-react-native/package.json b/packages/powersync-sdk-react-native/package.json index 713ae49b..7ef5c945 100644 --- a/packages/powersync-sdk-react-native/package.json +++ b/packages/powersync-sdk-react-native/package.json @@ -13,7 +13,6 @@ ], "scripts": { "build": "tsc -b", - "docs": "typedoc --out docs", "clean": "rm -rf lib tsconfig.tsbuildinfo", "watch": "tsc -b -w" },