diff --git a/apps/explorer/app/address/[id]/opengraph-image.tsx b/apps/explorer/app/address/[id]/opengraph-image.tsx index f2a0983b6..3d599ad70 100644 --- a/apps/explorer/app/address/[id]/opengraph-image.tsx +++ b/apps/explorer/app/address/[id]/opengraph-image.tsx @@ -1,4 +1,4 @@ -import { getSiaCentralAddress } from '@siafoundation/sia-central' +import { getSiaCentralAddress } from '@siafoundation/sia-central-js' import { humanSiacoin, humanSiafund } from '@siafoundation/units' import { getOGImage } from '../../../components/OGImageEntity' import { siaCentralApi } from '../../../config' diff --git a/apps/explorer/app/address/[id]/page.tsx b/apps/explorer/app/address/[id]/page.tsx index d3e6e0512..13346ef50 100644 --- a/apps/explorer/app/address/[id]/page.tsx +++ b/apps/explorer/app/address/[id]/page.tsx @@ -1,4 +1,4 @@ -import { getSiaCentralAddress } from '@siafoundation/sia-central' +import { getSiaCentralAddress } from '@siafoundation/sia-central-js' import { Address } from '../../../components/Address' import { Metadata } from 'next' import { routes } from '../../../config/routes' diff --git a/apps/explorer/app/block/[id]/opengraph-image.tsx b/apps/explorer/app/block/[id]/opengraph-image.tsx index a229cdfe3..9ef84573b 100644 --- a/apps/explorer/app/block/[id]/opengraph-image.tsx +++ b/apps/explorer/app/block/[id]/opengraph-image.tsx @@ -1,4 +1,4 @@ -import { getSiaCentralBlock } from '@siafoundation/sia-central' +import { getSiaCentralBlock } from '@siafoundation/sia-central-js' import { humanDate } from '@siafoundation/units' import { getOGImage } from '../../../components/OGImageEntity' import { siaCentralApi } from '../../../config' diff --git a/apps/explorer/app/block/[id]/page.tsx b/apps/explorer/app/block/[id]/page.tsx index 5d6d679cd..e3f26bc2a 100644 --- a/apps/explorer/app/block/[id]/page.tsx +++ b/apps/explorer/app/block/[id]/page.tsx @@ -2,7 +2,7 @@ import { getTitleId } from '@siafoundation/design-system' import { Block } from '../../../components/Block' import { routes } from '../../../config/routes' import { Metadata } from 'next' -import { getSiaCentralBlock } from '@siafoundation/sia-central' +import { getSiaCentralBlock } from '@siafoundation/sia-central-js' import { buildMetadata } from '../../../lib/utils' import { siaCentralApi } from '../../../config' import { notFound } from 'next/navigation' diff --git a/apps/explorer/app/contract/[id]/opengraph-image.tsx b/apps/explorer/app/contract/[id]/opengraph-image.tsx index 0901d0b04..5a431eb0d 100644 --- a/apps/explorer/app/contract/[id]/opengraph-image.tsx +++ b/apps/explorer/app/contract/[id]/opengraph-image.tsx @@ -1,7 +1,7 @@ import { getSiaCentralContract, getSiaCentralExchangeRates, -} from '@siafoundation/sia-central' +} from '@siafoundation/sia-central-js' import { humanBytes, humanDate } from '@siafoundation/units' import { getOGImage } from '../../../components/OGImageEntity' import { siaCentralApi } from '../../../config' diff --git a/apps/explorer/app/contract/[id]/page.tsx b/apps/explorer/app/contract/[id]/page.tsx index 44b300bf8..209d0a818 100644 --- a/apps/explorer/app/contract/[id]/page.tsx +++ b/apps/explorer/app/contract/[id]/page.tsx @@ -1,9 +1,9 @@ +import { SiaCentralContract } from '@siafoundation/sia-central-types' import { - SiaCentralContract, getSiaCentralContract, getSiaCentralExchangeRates, getSiaCentralTransaction, -} from '@siafoundation/sia-central' +} from '@siafoundation/sia-central-js' import { ContractView } from '../../../components/ContractView' import { Metadata } from 'next' import { routes } from '../../../config/routes' diff --git a/apps/explorer/app/host/[id]/opengraph-image.tsx b/apps/explorer/app/host/[id]/opengraph-image.tsx index f38b9933b..50b188f5d 100644 --- a/apps/explorer/app/host/[id]/opengraph-image.tsx +++ b/apps/explorer/app/host/[id]/opengraph-image.tsx @@ -1,7 +1,7 @@ import { getSiaCentralExchangeRates, getSiaCentralHost, -} from '@siafoundation/sia-central' +} from '@siafoundation/sia-central-js' import { getOGImage } from '../../../components/OGImageEntity' import { siaCentralApi } from '../../../config' import { diff --git a/apps/explorer/app/host/[id]/page.tsx b/apps/explorer/app/host/[id]/page.tsx index 7c6e5d525..30d9bd755 100644 --- a/apps/explorer/app/host/[id]/page.tsx +++ b/apps/explorer/app/host/[id]/page.tsx @@ -1,7 +1,7 @@ import { getSiaCentralExchangeRates, getSiaCentralHost, -} from '@siafoundation/sia-central' +} from '@siafoundation/sia-central-js' import { Metadata } from 'next' import { routes } from '../../../config/routes' import { buildMetadata } from '../../../lib/utils' diff --git a/apps/explorer/app/opengraph-image.tsx b/apps/explorer/app/opengraph-image.tsx index 3fed91113..2fc57ef11 100644 --- a/apps/explorer/app/opengraph-image.tsx +++ b/apps/explorer/app/opengraph-image.tsx @@ -1,7 +1,7 @@ import { getSiaCentralBlockLatest, getSiaCentralHostsNetworkMetrics, -} from '@siafoundation/sia-central' +} from '@siafoundation/sia-central-js' import { getOGImage } from '../components/OGImage' import { network, siaCentralApi } from '../config' import { humanBytes } from '@siafoundation/units' diff --git a/apps/explorer/app/page.tsx b/apps/explorer/app/page.tsx index b039e8695..9e9a105ea 100644 --- a/apps/explorer/app/page.tsx +++ b/apps/explorer/app/page.tsx @@ -6,7 +6,7 @@ import { getSiaCentralExchangeRates, getSiaCentralHosts, getSiaCentralHostsNetworkMetrics, -} from '@siafoundation/sia-central' +} from '@siafoundation/sia-central-js' import { buildMetadata } from '../lib/utils' import { humanBytes } from '@siafoundation/units' import { getLastFewBlocks } from '../lib/blocks' diff --git a/apps/explorer/app/tx/[id]/opengraph-image.tsx b/apps/explorer/app/tx/[id]/opengraph-image.tsx index 6683bc3a6..41fac3ece 100644 --- a/apps/explorer/app/tx/[id]/opengraph-image.tsx +++ b/apps/explorer/app/tx/[id]/opengraph-image.tsx @@ -1,4 +1,4 @@ -import { getSiaCentralTransaction } from '@siafoundation/sia-central' +import { getSiaCentralTransaction } from '@siafoundation/sia-central-js' import { humanDate } from '@siafoundation/units' import { getOGImage } from '../../../components/OGImageEntity' import { siaCentralApi } from '../../../config' diff --git a/apps/explorer/app/tx/[id]/page.tsx b/apps/explorer/app/tx/[id]/page.tsx index 083cf70e5..65876e03c 100644 --- a/apps/explorer/app/tx/[id]/page.tsx +++ b/apps/explorer/app/tx/[id]/page.tsx @@ -1,7 +1,7 @@ import { Metadata } from 'next' import { routes } from '../../../config/routes' import { Transaction } from '../../../components/Transaction' -import { getSiaCentralTransaction } from '@siafoundation/sia-central' +import { getSiaCentralTransaction } from '@siafoundation/sia-central-js' import { buildMetadata } from '../../../lib/utils' import { siaCentralApi } from '../../../config' import { notFound } from 'next/navigation' diff --git a/apps/explorer/components/Address/index.tsx b/apps/explorer/components/Address/index.tsx index 12e40fbe0..5486d5ddb 100644 --- a/apps/explorer/components/Address/index.tsx +++ b/apps/explorer/components/Address/index.tsx @@ -17,7 +17,7 @@ import { routes } from '../../config/routes' import { EntityHeading } from '../EntityHeading' import BigNumber from 'bignumber.js' import { ContentLayout } from '../ContentLayout' -import { SiaCentralAddressResponse } from '@siafoundation/sia-central' +import { SiaCentralAddressResponse } from '@siafoundation/sia-central-types' type Tab = 'transactions' | 'evolution' | 'utxos' diff --git a/apps/explorer/components/Block/index.tsx b/apps/explorer/components/Block/index.tsx index a171427cb..082023adf 100644 --- a/apps/explorer/components/Block/index.tsx +++ b/apps/explorer/components/Block/index.tsx @@ -5,7 +5,7 @@ import { useMemo } from 'react' import { routes } from '../../config/routes' import { EntityHeading } from '../EntityHeading' import { ContentLayout } from '../ContentLayout' -import { SiaCentralBlock } from '@siafoundation/sia-central' +import { SiaCentralBlock } from '@siafoundation/sia-central-types' type Props = { block: SiaCentralBlock diff --git a/apps/explorer/components/Contract/ContractHeader.tsx b/apps/explorer/components/Contract/ContractHeader.tsx index 1b6ed7956..e55955b20 100644 --- a/apps/explorer/components/Contract/ContractHeader.tsx +++ b/apps/explorer/components/Contract/ContractHeader.tsx @@ -4,10 +4,8 @@ import { LinkButton, } from '@siafoundation/design-system' import { ArrowLeft16, ArrowRight16 } from '@siafoundation/react-icons' -import { - SiaCentralContract, - getSiaCentralBlockLatest, -} from '@siafoundation/sia-central' +import { SiaCentralContract } from '@siafoundation/sia-central-types' +import { getSiaCentralBlockLatest } from '@siafoundation/sia-central-js' import { lowerCase } from '@technically/lodash' import { routes } from '../../config/routes' import { EntityHeading } from '../EntityHeading' diff --git a/apps/explorer/components/Contract/index.tsx b/apps/explorer/components/Contract/index.tsx index 719202904..74ee5208b 100644 --- a/apps/explorer/components/Contract/index.tsx +++ b/apps/explorer/components/Contract/index.tsx @@ -6,7 +6,7 @@ import { SiaCentralContract, SiaCentralExchangeRates, SiaCentralPartialSiacoinOutput, -} from '@siafoundation/sia-central' +} from '@siafoundation/sia-central-types' import { humanBytes, humanDate, humanSiacoin } from '@siafoundation/units' import { EntityList, EntityListItemProps } from '@siafoundation/design-system' import { DatumProps, ExplorerDatum } from '../ExplorerDatum' diff --git a/apps/explorer/components/ContractView/index.tsx b/apps/explorer/components/ContractView/index.tsx index 62d33eb05..da4146537 100644 --- a/apps/explorer/components/ContractView/index.tsx +++ b/apps/explorer/components/ContractView/index.tsx @@ -4,7 +4,7 @@ import { SiaCentralContract, SiaCentralExchangeRates, SiaCentralTransaction, -} from '@siafoundation/sia-central' +} from '@siafoundation/sia-central-types' import { Contract } from '../Contract' type Props = { diff --git a/apps/explorer/components/Home/HostListItem.tsx b/apps/explorer/components/Home/HostListItem.tsx index 4ca4bd7c9..9328ea6e4 100644 --- a/apps/explorer/components/Home/HostListItem.tsx +++ b/apps/explorer/components/Home/HostListItem.tsx @@ -13,7 +13,7 @@ import { CloudUpload16, VmdkDisk16, } from '@siafoundation/react-icons' -import { SiaCentralExchangeRates } from '@siafoundation/sia-central' +import { SiaCentralExchangeRates } from '@siafoundation/sia-central-types' import { getDownloadCost, getDownloadSpeed, diff --git a/apps/explorer/components/Home/index.tsx b/apps/explorer/components/Home/index.tsx index 7e9873645..9a8f33704 100644 --- a/apps/explorer/components/Home/index.tsx +++ b/apps/explorer/components/Home/index.tsx @@ -15,7 +15,7 @@ import { SiaCentralExchangeRates, SiaCentralHost, SiaCentralHostsNetworkMetricsResponse, -} from '@siafoundation/sia-central' +} from '@siafoundation/sia-central-types' import { hashToAvatar } from '../../lib/avatar' import { humanBytes, diff --git a/apps/explorer/components/Host/HostHeader.tsx b/apps/explorer/components/Host/HostHeader.tsx index 062c1d775..b7111e5a2 100644 --- a/apps/explorer/components/Host/HostHeader.tsx +++ b/apps/explorer/components/Host/HostHeader.tsx @@ -2,7 +2,7 @@ import { Avatar } from '@siafoundation/design-system' import { SiaCentralExchangeRates, SiaCentralHost, -} from '@siafoundation/sia-central' +} from '@siafoundation/sia-central-types' import { hashToAvatar } from '../../lib/avatar' import { HostPricing } from './HostPricing' import { HostInfo } from './HostInfo' diff --git a/apps/explorer/components/Host/HostInfo.tsx b/apps/explorer/components/Host/HostInfo.tsx index 2d9833cd6..576bfe729 100644 --- a/apps/explorer/components/Host/HostInfo.tsx +++ b/apps/explorer/components/Host/HostInfo.tsx @@ -11,7 +11,7 @@ import { Time16, WarningFilled16, } from '@siafoundation/react-icons' -import { SiaCentralHost } from '@siafoundation/sia-central' +import { SiaCentralHost } from '@siafoundation/sia-central-types' import { humanDate } from '@siafoundation/units' import { formatDistance } from 'date-fns' diff --git a/apps/explorer/components/Host/HostPricing.tsx b/apps/explorer/components/Host/HostPricing.tsx index 04ed4799f..7988a6ec8 100644 --- a/apps/explorer/components/Host/HostPricing.tsx +++ b/apps/explorer/components/Host/HostPricing.tsx @@ -6,7 +6,7 @@ import { CloudUpload16, VmdkDisk16, } from '@siafoundation/react-icons' -import { SiaCentralExchangeRates } from '@siafoundation/sia-central' +import { SiaCentralExchangeRates } from '@siafoundation/sia-central-types' import { useMemo } from 'react' import { getDownloadCost, diff --git a/apps/explorer/components/Host/HostSettings.tsx b/apps/explorer/components/Host/HostSettings.tsx index ec4f1f7a9..d10fc8cfd 100644 --- a/apps/explorer/components/Host/HostSettings.tsx +++ b/apps/explorer/components/Host/HostSettings.tsx @@ -1,7 +1,7 @@ 'use client' import { useMemo } from 'react' -import { SiaCentralExchangeRates } from '@siafoundation/sia-central' +import { SiaCentralExchangeRates } from '@siafoundation/sia-central-types' import { DatumProps, ExplorerDatum } from '../ExplorerDatum' import { Panel, toFixedOrPrecision } from '@siafoundation/design-system' import BigNumber from 'bignumber.js' diff --git a/apps/explorer/components/Host/index.tsx b/apps/explorer/components/Host/index.tsx index 4ba5fbac2..e58c4dad3 100644 --- a/apps/explorer/components/Host/index.tsx +++ b/apps/explorer/components/Host/index.tsx @@ -1,7 +1,7 @@ import { SiaCentralExchangeRates, SiaCentralHost, -} from '@siafoundation/sia-central' +} from '@siafoundation/sia-central-types' import { ContentLayout } from '../ContentLayout' import { HostHeader } from './HostHeader' import { HostSettings } from './HostSettings' diff --git a/apps/explorer/components/Host/types.ts b/apps/explorer/components/Host/types.ts index 3d2221184..9be32e2f6 100644 --- a/apps/explorer/components/Host/types.ts +++ b/apps/explorer/components/Host/types.ts @@ -3,7 +3,7 @@ import { SiaCentralHost, SiaCentralHostSettings, -} from '@siafoundation/sia-central' +} from '@siafoundation/sia-central-types' export type SiaCentralHostScanned = SiaCentralHost & { settings: SiaCentralHostSettings diff --git a/apps/explorer/components/Transaction/TransactionHeader.tsx b/apps/explorer/components/Transaction/TransactionHeader.tsx index c2ac374fd..d33bd01fd 100644 --- a/apps/explorer/components/Transaction/TransactionHeader.tsx +++ b/apps/explorer/components/Transaction/TransactionHeader.tsx @@ -1,5 +1,5 @@ import { Badge, Text, Tooltip } from '@siafoundation/design-system' -import { SiaCentralTransaction } from '@siafoundation/sia-central' +import { SiaCentralTransaction } from '@siafoundation/sia-central-types' import { humanDate } from '@siafoundation/units' import { routes } from '../../config/routes' import { EntityHeading } from '../EntityHeading' diff --git a/apps/explorer/components/Transaction/index.tsx b/apps/explorer/components/Transaction/index.tsx index 444621be5..bec523b30 100644 --- a/apps/explorer/components/Transaction/index.tsx +++ b/apps/explorer/components/Transaction/index.tsx @@ -2,7 +2,7 @@ import { useMemo } from 'react' import BigNumber from 'bignumber.js' -import { SiaCentralTransaction } from '@siafoundation/sia-central' +import { SiaCentralTransaction } from '@siafoundation/sia-central-types' import { EntityList, EntityListItemProps } from '@siafoundation/design-system' import { routes } from '../../config/routes' import { ContentLayout } from '../ContentLayout' diff --git a/apps/explorer/hooks/useExchangeRate.ts b/apps/explorer/hooks/useExchangeRate.ts index b00aa15d0..578cf4e07 100644 --- a/apps/explorer/hooks/useExchangeRate.ts +++ b/apps/explorer/hooks/useExchangeRate.ts @@ -1,7 +1,7 @@ 'use client' import { useAppSettings } from '@siafoundation/react-core' -import { SiaCentralExchangeRates } from '@siafoundation/sia-central' +import { SiaCentralExchangeRates } from '@siafoundation/sia-central-types' export function useExchangeRate(rates?: SiaCentralExchangeRates) { const { diff --git a/apps/explorer/lib/blocks.ts b/apps/explorer/lib/blocks.ts index 2faa1123e..ede612bc0 100644 --- a/apps/explorer/lib/blocks.ts +++ b/apps/explorer/lib/blocks.ts @@ -1,9 +1,9 @@ import { siaCentralApi } from '../config' +import { SiaCentralBlock } from '@siafoundation/sia-central-types' import { - SiaCentralBlock, getSiaCentralBlock, getSiaCentralBlocks, -} from '@siafoundation/sia-central' +} from '@siafoundation/sia-central-js' import { range } from '@technically/lodash' export async function getLastFewBlocksOneByOne(block?: SiaCentralBlock) { diff --git a/apps/hostd/contexts/config/fields.tsx b/apps/hostd/contexts/config/fields.tsx index a520394cb..1c2bc87fc 100644 --- a/apps/hostd/contexts/config/fields.tsx +++ b/apps/hostd/contexts/config/fields.tsx @@ -2,7 +2,7 @@ import { blocksToMonths } from '@siafoundation/units' import { ConfigFields } from '@siafoundation/design-system' import BigNumber from 'bignumber.js' import { dnsProviderOptions, initialValues, scDecimalPlaces } from './types' -import { SiaCentralExchangeRates } from '@siafoundation/sia-central' +import { SiaCentralExchangeRates } from '@siafoundation/sia-central-types' import { calculateMaxCollateral } from './transform' type Categories = 'host' | 'pricing' | 'DNS' | 'bandwidth' | 'RHP3' diff --git a/apps/renterd/components/Hosts/HostMap/HostItem.tsx b/apps/renterd/components/Hosts/HostMap/HostItem.tsx index a57081b84..02f12e19b 100644 --- a/apps/renterd/components/Hosts/HostMap/HostItem.tsx +++ b/apps/renterd/components/Hosts/HostMap/HostItem.tsx @@ -7,7 +7,7 @@ import { } from '@siafoundation/design-system' import { cx } from 'class-variance-authority' import BigNumber from 'bignumber.js' -import { SiaCentralHost } from '@siafoundation/sia-central' +import { SiaCentralHost } from '@siafoundation/sia-central-types' import { monthsToBlocks, TBToBytes, diff --git a/apps/renterd/contexts/config/resources.ts b/apps/renterd/contexts/config/resources.ts index 8baaa92ec..8fe8e4b3a 100644 --- a/apps/renterd/contexts/config/resources.ts +++ b/apps/renterd/contexts/config/resources.ts @@ -7,7 +7,7 @@ import { RedundancySettings, UploadPackingSettings, } from '@siafoundation/renterd-types' -import { SiaCentralHostsNetworkAveragesResponse } from '@siafoundation/sia-central' +import { SiaCentralHostsNetworkAveragesResponse } from '@siafoundation/sia-central-types' import BigNumber from 'bignumber.js' import { TBToBytes } from '@siafoundation/units' diff --git a/apps/renterd/contexts/hosts/dataset.ts b/apps/renterd/contexts/hosts/dataset.ts index 4247fc8cb..be8dcc346 100644 --- a/apps/renterd/contexts/hosts/dataset.ts +++ b/apps/renterd/contexts/hosts/dataset.ts @@ -10,7 +10,7 @@ import { } from '@siafoundation/renterd-react' import { ContractData } from '../contracts/types' import { useApp } from '../app' -import { SiaCentralHost } from '@siafoundation/sia-central' +import { SiaCentralHost } from '@siafoundation/sia-central-types' export function useDataset({ autopilotStatus, diff --git a/apps/website/content/exchangeRates.ts b/apps/website/content/exchangeRates.ts index 2d92b5c7e..92d88c0b0 100644 --- a/apps/website/content/exchangeRates.ts +++ b/apps/website/content/exchangeRates.ts @@ -1,4 +1,4 @@ -import { getSiaCentralExchangeRates } from '@siafoundation/sia-central' +import { getSiaCentralExchangeRates } from '@siafoundation/sia-central-js' import { getCacheValue } from '../lib/cache' import { getMinutesInSeconds } from '../lib/time' diff --git a/apps/website/content/geoHosts.ts b/apps/website/content/geoHosts.ts index bc5c09b43..9d0397eba 100644 --- a/apps/website/content/geoHosts.ts +++ b/apps/website/content/geoHosts.ts @@ -1,4 +1,5 @@ -import { SiaCentralHost, getSiaCentralHosts } from '@siafoundation/sia-central' +import { SiaCentralHost } from '@siafoundation/sia-central-types' +import { getSiaCentralHosts } from '@siafoundation/sia-central-js' import { getCacheValue } from '../lib/cache' import { getMinutesInSeconds } from '../lib/time' diff --git a/apps/website/content/stats.ts b/apps/website/content/stats.ts index abd409a4a..6688003c2 100644 --- a/apps/website/content/stats.ts +++ b/apps/website/content/stats.ts @@ -6,7 +6,7 @@ import { getMinutesInSeconds } from '../lib/time' import { getSiaCentralBlockLatest, getSiaCentralHostsNetworkMetrics, -} from '@siafoundation/sia-central' +} from '@siafoundation/sia-central-js' const maxAge = getMinutesInSeconds(5) diff --git a/libs/design-system/src/core/SiacoinField.spec.tsx b/libs/design-system/src/core/SiacoinField.spec.tsx index 218ad04e5..1a78538e8 100644 --- a/libs/design-system/src/core/SiacoinField.spec.tsx +++ b/libs/design-system/src/core/SiacoinField.spec.tsx @@ -8,7 +8,7 @@ import { SiacoinField } from './SiacoinField' import { fireEvent, render, waitFor, act } from '@testing-library/react' import userEvent from '@testing-library/user-event' import { useState } from 'react' -import { SiaCentralExchangeRatesResponse } from '@siafoundation/sia-central' +import { SiaCentralExchangeRatesResponse } from '@siafoundation/sia-central-types' import { setupServer } from 'msw/node' import { HttpResponse, http } from 'msw' diff --git a/libs/sia-central/.babelrc b/libs/sia-central-js/.babelrc similarity index 100% rename from libs/sia-central/.babelrc rename to libs/sia-central-js/.babelrc diff --git a/libs/sia-central/.eslintrc.json b/libs/sia-central-js/.eslintrc.json similarity index 84% rename from libs/sia-central/.eslintrc.json rename to libs/sia-central-js/.eslintrc.json index 1da02672e..12e4c0bb1 100644 --- a/libs/sia-central/.eslintrc.json +++ b/libs/sia-central-js/.eslintrc.json @@ -5,7 +5,7 @@ "@nx/dependency-checks": [ "error", { - "ignoredFiles": ["libs/sia-central/rollup.config.js"] + "ignoredFiles": ["libs/sia-central-js/rollup.config.js"] } ] }, diff --git a/libs/sia-central/CHANGELOG.md b/libs/sia-central-js/CHANGELOG.md similarity index 93% rename from libs/sia-central/CHANGELOG.md rename to libs/sia-central-js/CHANGELOG.md index 2cd2e9d09..2e7ed27ce 100644 --- a/libs/sia-central/CHANGELOG.md +++ b/libs/sia-central-js/CHANGELOG.md @@ -1,4 +1,4 @@ -# @siafoundation/sia-central +# @siafoundation/sia-central-js ## 0.3.3 diff --git a/libs/sia-central-js/README.md b/libs/sia-central-js/README.md new file mode 100644 index 000000000..0e54a0556 --- /dev/null +++ b/libs/sia-central-js/README.md @@ -0,0 +1,7 @@ +# sia-central-js + +Methods and types for interacting with the Sia Central API. + +## Running unit tests + +Run `nx test sia-central-js` to execute the unit tests via [Jest](https://jestjs.io). diff --git a/libs/sia-central/jest.config.ts b/libs/sia-central-js/jest.config.ts similarity index 80% rename from libs/sia-central/jest.config.ts rename to libs/sia-central-js/jest.config.ts index e355f2554..b1b82c844 100644 --- a/libs/sia-central/jest.config.ts +++ b/libs/sia-central-js/jest.config.ts @@ -1,6 +1,6 @@ /* eslint-disable */ export default { - displayName: 'sia-central', + displayName: 'sia-central-js', preset: '../../jest.preset.js', transform: { '^(?!.*\\.(js|jsx|ts|tsx|css|json)$)': '@nx/react/plugins/jest', @@ -13,5 +13,5 @@ export default { ], }, moduleFileExtensions: ['ts', 'tsx', 'js', 'jsx'], - coverageDirectory: '../../coverage/libs/sia-central', + coverageDirectory: '../../coverage/libs/sia-central-js', } diff --git a/libs/sia-central/package.json b/libs/sia-central-js/package.json similarity index 58% rename from libs/sia-central/package.json rename to libs/sia-central-js/package.json index b7e2a2d0f..5fe891726 100644 --- a/libs/sia-central/package.json +++ b/libs/sia-central-js/package.json @@ -1,10 +1,11 @@ { - "name": "@siafoundation/sia-central", + "name": "@siafoundation/sia-central-js", "description": "Methods and types for interacting with the Sia Central API.", "version": "0.3.3", "license": "MIT", "dependencies": { - "@technically/lodash": "^4.17.0" + "@technically/lodash": "^4.17.0", + "@siafoundation/sia-central-types": "0.0.0" }, "types": "./src/index.d.ts" } diff --git a/libs/sia-central/project.json b/libs/sia-central-js/project.json similarity index 56% rename from libs/sia-central/project.json rename to libs/sia-central-js/project.json index d02bc8bf0..a094d9ce0 100644 --- a/libs/sia-central/project.json +++ b/libs/sia-central-js/project.json @@ -1,7 +1,7 @@ { - "name": "sia-central", + "name": "sia-central-js", "$schema": "../../node_modules/nx/schemas/project-schema.json", - "sourceRoot": "libs/sia-central/src", + "sourceRoot": "libs/sia-central-js/src", "projectType": "library", "tags": [], "targets": { @@ -9,17 +9,17 @@ "executor": "@nx/rollup:rollup", "outputs": ["{options.outputPath}"], "options": { - "outputPath": "dist/libs/sia-central", - "tsConfig": "libs/sia-central/tsconfig.lib.json", - "project": "libs/sia-central/package.json", - "entryFile": "libs/sia-central/src/index.ts", + "outputPath": "dist/libs/sia-central-js", + "tsConfig": "libs/sia-central-js/tsconfig.lib.json", + "project": "libs/sia-central-js/package.json", + "entryFile": "libs/sia-central-js/src/index.ts", "external": ["react/jsx-runtime"], "compiler": "tsc", "outputFileName": "index.js", - "rollupConfig": "libs/sia-central/rollup.config.js", + "rollupConfig": "libs/sia-central-js/rollup.config.js", "assets": [ { - "glob": "libs/sia-central/*.md", + "glob": "libs/sia-central-js/*.md", "input": ".", "output": "." } @@ -33,9 +33,9 @@ }, "test": { "executor": "@nx/jest:jest", - "outputs": ["{workspaceRoot}/coverage/libs/sia-central"], + "outputs": ["{workspaceRoot}/coverage/libs/sia-central-js"], "options": { - "jestConfig": "libs/sia-central/jest.config.ts" + "jestConfig": "libs/sia-central-js/jest.config.ts" } } } diff --git a/libs/sia-central/rollup.config.js b/libs/sia-central-js/rollup.config.js similarity index 100% rename from libs/sia-central/rollup.config.js rename to libs/sia-central-js/rollup.config.js diff --git a/libs/sia-central-js/src/address.ts b/libs/sia-central-js/src/address.ts new file mode 100644 index 000000000..6dbd7516b --- /dev/null +++ b/libs/sia-central-js/src/address.ts @@ -0,0 +1,18 @@ +import { runFetch } from './fetch' +import { + api, + SiaCentralAddressParams, + SiaCentralAddressResponse, +} from '@siafoundation/sia-central-types' + +export async function getSiaCentralAddress(args: { + params: SiaCentralAddressParams + config?: { + api: string + } +}) { + const { params, config } = args + return runFetch( + `${config?.api || api}/wallet/addresses/${params.id}` + ) +} diff --git a/libs/sia-central/src/siaCentralBlock.tsx b/libs/sia-central-js/src/block.ts similarity index 61% rename from libs/sia-central/src/siaCentralBlock.tsx rename to libs/sia-central-js/src/block.ts index 6c96816f9..ea2de9d4e 100644 --- a/libs/sia-central/src/siaCentralBlock.tsx +++ b/libs/sia-central-js/src/block.ts @@ -1,14 +1,9 @@ import { runFetch } from './fetch' -import { SiaCentralBlock, api } from './types' - -export type SiaCentralBlockParams = { - id: string -} - -export type SiaCentralBlockResponse = { - message: string - block: SiaCentralBlock -} +import { + api, + SiaCentralBlockParams, + SiaCentralBlockResponse, +} from '@siafoundation/sia-central-types' export async function getSiaCentralBlock(args: { params: SiaCentralBlockParams diff --git a/libs/sia-central/src/siaCentralBlockLatest.tsx b/libs/sia-central-js/src/blockLatest.ts similarity index 61% rename from libs/sia-central/src/siaCentralBlockLatest.tsx rename to libs/sia-central-js/src/blockLatest.ts index 8ba78268c..3ab7194be 100644 --- a/libs/sia-central/src/siaCentralBlockLatest.tsx +++ b/libs/sia-central-js/src/blockLatest.ts @@ -1,10 +1,8 @@ -import { api, SiaCentralBlock } from './types' import { runFetch } from './fetch' - -export type SiaCentralBlockLatestResponse = { - message: string - block: Omit -} +import { + api, + SiaCentralBlockLatestResponse, +} from '@siafoundation/sia-central-types' export async function getSiaCentralBlockLatest(args?: { config?: { diff --git a/libs/sia-central/src/siaCentralBlocks.tsx b/libs/sia-central-js/src/blocks.ts similarity index 61% rename from libs/sia-central/src/siaCentralBlocks.tsx rename to libs/sia-central-js/src/blocks.ts index e38408102..ab2e829af 100644 --- a/libs/sia-central/src/siaCentralBlocks.tsx +++ b/libs/sia-central-js/src/blocks.ts @@ -1,16 +1,10 @@ -import { api, SiaCentralBlock } from './types' +import { + api, + SiaCentralBlocksPayload, + SiaCentralBlocksResponse, +} from '@siafoundation/sia-central-types' import { runFetch } from './fetch' -export type SiaCentralBlocksResponse = { - message: string - blocks: SiaCentralBlock[] -} - -export type SiaCentralBlocksPayload = { - block_ids?: number[] - heights?: number[] -} - export async function getSiaCentralBlocks(args: { payload: SiaCentralBlocksPayload config?: { diff --git a/libs/sia-central/src/siaCentralContract.tsx b/libs/sia-central-js/src/contract.ts similarity index 60% rename from libs/sia-central/src/siaCentralContract.tsx rename to libs/sia-central-js/src/contract.ts index 61863533a..02d4cb6e1 100644 --- a/libs/sia-central/src/siaCentralContract.tsx +++ b/libs/sia-central-js/src/contract.ts @@ -1,14 +1,9 @@ import { runFetch } from './fetch' -import { api, SiaCentralContract } from './types' - -export type SiaCentralContractParams = { - id: string -} - -export type SiaCentralContractResponse = { - message: string - contract: SiaCentralContract -} +import { + api, + SiaCentralContractParams, + SiaCentralContractResponse, +} from '@siafoundation/sia-central-types' export async function getSiaCentralContract(args: { params: SiaCentralContractParams diff --git a/libs/sia-central-js/src/exchangeRates.ts b/libs/sia-central-js/src/exchangeRates.ts new file mode 100644 index 000000000..75fd6cc6e --- /dev/null +++ b/libs/sia-central-js/src/exchangeRates.ts @@ -0,0 +1,16 @@ +import { runFetch } from './fetch' +import { + api, + SiaCentralExchangeRatesResponse, +} from '@siafoundation/sia-central-types' + +export async function getSiaCentralExchangeRates(args?: { + config?: { + api: string + } +}) { + const { config } = args || {} + return runFetch( + `${config?.api || api}/market/exchange-rate?currencies=sc` + ) +} diff --git a/libs/sia-central/src/fetch.ts b/libs/sia-central-js/src/fetch.ts similarity index 100% rename from libs/sia-central/src/fetch.ts rename to libs/sia-central-js/src/fetch.ts diff --git a/libs/sia-central/src/siaCentralHost.tsx b/libs/sia-central-js/src/host.ts similarity index 58% rename from libs/sia-central/src/siaCentralHost.tsx rename to libs/sia-central-js/src/host.ts index 179960b02..ec06c60bf 100644 --- a/libs/sia-central/src/siaCentralHost.tsx +++ b/libs/sia-central-js/src/host.ts @@ -1,15 +1,9 @@ import { runFetch } from './fetch' -import { SiaCentralHost, api } from './types' - -export type SiaCentralHostParams = { - id: string -} - -export type SiaCentralHostResponse = { - message: string - type: string - host: SiaCentralHost -} +import { + api, + SiaCentralHostParams, + SiaCentralHostResponse, +} from '@siafoundation/sia-central-types' export async function getSiaCentralHost(args: { params: SiaCentralHostParams diff --git a/libs/sia-central/src/siaCentralHosts.tsx b/libs/sia-central-js/src/hosts.ts similarity index 67% rename from libs/sia-central/src/siaCentralHosts.tsx rename to libs/sia-central-js/src/hosts.ts index b8b4bf7c7..8e9f3f1b5 100644 --- a/libs/sia-central/src/siaCentralHosts.tsx +++ b/libs/sia-central-js/src/hosts.ts @@ -1,19 +1,10 @@ import { merge } from '@technically/lodash' import { runFetch } from './fetch' -import { SiaCentralHost, api } from './types' - -export type SiaCentralHostsParams = { - limit?: number - page?: number -} - -export type SiaCentralHostsResponse = { - message: string - count: number - total: number - type: string - hosts: SiaCentralHost[] -} +import { + api, + SiaCentralHostsParams, + SiaCentralHostsResponse, +} from '@siafoundation/sia-central-types' export async function getSiaCentralHosts(args?: { params?: SiaCentralHostsParams diff --git a/libs/sia-central/src/siaCentralHostsNetworkAverages.tsx b/libs/sia-central-js/src/hostsNetworkAverages.ts similarity index 62% rename from libs/sia-central/src/siaCentralHostsNetworkAverages.tsx rename to libs/sia-central-js/src/hostsNetworkAverages.ts index e8ef24947..008ec299d 100644 --- a/libs/sia-central/src/siaCentralHostsNetworkAverages.tsx +++ b/libs/sia-central-js/src/hostsNetworkAverages.ts @@ -1,10 +1,8 @@ import { runFetch } from './fetch' -import { SiaCentralNetworkStats, api } from './types' - -export type SiaCentralHostsNetworkAveragesResponse = { - message: string - type: string -} & SiaCentralNetworkStats +import { + api, + SiaCentralHostsNetworkAveragesResponse, +} from '@siafoundation/sia-central-types' export async function getSiaCentralHostsNetworkAverages(args?: { config?: { diff --git a/libs/sia-central-js/src/hostsNetworkMetrics.ts b/libs/sia-central-js/src/hostsNetworkMetrics.ts new file mode 100644 index 000000000..dda6ace05 --- /dev/null +++ b/libs/sia-central-js/src/hostsNetworkMetrics.ts @@ -0,0 +1,16 @@ +import { runFetch } from './fetch' +import { + api, + SiaCentralHostsNetworkMetricsResponse, +} from '@siafoundation/sia-central-types' + +export async function getSiaCentralHostsNetworkMetrics(args?: { + config?: { + api: string + } +}) { + const { config } = args || {} + return runFetch( + `${config?.api || api}/hosts/network/metrics` + ) +} diff --git a/libs/sia-central-js/src/index.ts b/libs/sia-central-js/src/index.ts new file mode 100644 index 000000000..2d5b3ffe9 --- /dev/null +++ b/libs/sia-central-js/src/index.ts @@ -0,0 +1,12 @@ +export * from './address' +export * from './blockLatest' +export * from './block' +export * from './blocks' +export * from './contract' +export * from './host' +export * from './hosts' +export * from './hostsNetworkAverages' +export * from './hostsNetworkMetrics' +export * from './exchangeRates' +export * from './transaction' +export * from './search' diff --git a/libs/sia-central-js/src/search.ts b/libs/sia-central-js/src/search.ts new file mode 100644 index 000000000..657102031 --- /dev/null +++ b/libs/sia-central-js/src/search.ts @@ -0,0 +1,18 @@ +import { runFetch } from './fetch' +import { + api, + SiaCentralSearchParams, + SiaCentralSearchResponse, +} from '@siafoundation/sia-central-types' + +export async function getSiaCentralSearch(args: { + params: SiaCentralSearchParams + config?: { + api: string + } +}) { + const { params, config } = args + return runFetch( + `${config?.api || api}/explorer/search/${params.query}` + ) +} diff --git a/libs/sia-central/src/siaCentralTransaction.tsx b/libs/sia-central-js/src/transaction.ts similarity index 57% rename from libs/sia-central/src/siaCentralTransaction.tsx rename to libs/sia-central-js/src/transaction.ts index ecdb4217e..d99ac64d5 100644 --- a/libs/sia-central/src/siaCentralTransaction.tsx +++ b/libs/sia-central-js/src/transaction.ts @@ -1,16 +1,10 @@ -import { api, SiaCentralTransaction } from './types' +import { + api, + SiaCentralTransactionParams, + SiaCentralTransactionResponse, +} from '@siafoundation/sia-central-types' import { runFetch } from './fetch' -export type SiaCentralTransactionParams = { - id: string -} - -export type SiaCentralTransactionResponse = { - message: string - type?: 'error' - transaction: SiaCentralTransaction -} - export async function getSiaCentralTransaction(args: { params: SiaCentralTransactionParams config?: { diff --git a/libs/sia-central/tsconfig.json b/libs/sia-central-js/tsconfig.json similarity index 100% rename from libs/sia-central/tsconfig.json rename to libs/sia-central-js/tsconfig.json diff --git a/libs/sia-central/tsconfig.lib.json b/libs/sia-central-js/tsconfig.lib.json similarity index 100% rename from libs/sia-central/tsconfig.lib.json rename to libs/sia-central-js/tsconfig.lib.json diff --git a/libs/sia-central/tsconfig.spec.json b/libs/sia-central-js/tsconfig.spec.json similarity index 100% rename from libs/sia-central/tsconfig.spec.json rename to libs/sia-central-js/tsconfig.spec.json diff --git a/libs/sia-central-mock/package.json b/libs/sia-central-mock/package.json index 5e15aebbf..86c7d1870 100644 --- a/libs/sia-central-mock/package.json +++ b/libs/sia-central-mock/package.json @@ -4,8 +4,8 @@ "version": "0.0.0", "license": "MIT", "dependencies": { - "@siafoundation/sia-central": "0.3.3", - "playwright": "^1.42.1" + "playwright": "^1.42.1", + "@siafoundation/sia-central-types": "0.0.0" }, "types": "./src/index.d.ts" } diff --git a/libs/sia-central-mock/src/siaCentralExchangeRates.ts b/libs/sia-central-mock/src/siaCentralExchangeRates.ts index dda0d9be9..a3e0b5ab7 100644 --- a/libs/sia-central-mock/src/siaCentralExchangeRates.ts +++ b/libs/sia-central-mock/src/siaCentralExchangeRates.ts @@ -1,4 +1,4 @@ -import { SiaCentralExchangeRatesResponse } from '@siafoundation/sia-central' +import { SiaCentralExchangeRatesResponse } from '@siafoundation/sia-central-types' import { Page } from 'playwright' export function getMockSiaCentralExchangeRatesResponse(): SiaCentralExchangeRatesResponse { diff --git a/libs/sia-central-react/package.json b/libs/sia-central-react/package.json index e296c3f9b..4382828f3 100644 --- a/libs/sia-central-react/package.json +++ b/libs/sia-central-react/package.json @@ -3,9 +3,9 @@ "description": "React hooks for interacting with the Sia Central API.", "version": "3.0.0", "license": "MIT", - "peerDependencies": { + "dependencies": { "@siafoundation/react-core": "^1.1.0", - "@siafoundation/sia-central": "^0.3.3" + "@siafoundation/sia-central-types": "0.0.0" }, "types": "./src/index.d.ts" } diff --git a/libs/sia-central-react/src/useSiaCentralAddress.tsx b/libs/sia-central-react/src/useSiaCentralAddress.tsx index 7303c48e4..fb74c0393 100644 --- a/libs/sia-central-react/src/useSiaCentralAddress.tsx +++ b/libs/sia-central-react/src/useSiaCentralAddress.tsx @@ -7,7 +7,7 @@ import { api, SiaCentralAddressParams, SiaCentralAddressResponse, -} from '@siafoundation/sia-central' +} from '@siafoundation/sia-central-types' export function useSiaCentralAddress( args?: HookArgsSwr diff --git a/libs/sia-central-react/src/useSiaCentralBlock.tsx b/libs/sia-central-react/src/useSiaCentralBlock.tsx index 0f77e246d..e8240ee25 100644 --- a/libs/sia-central-react/src/useSiaCentralBlock.tsx +++ b/libs/sia-central-react/src/useSiaCentralBlock.tsx @@ -7,7 +7,7 @@ import { api, SiaCentralBlockParams, SiaCentralBlockResponse, -} from '@siafoundation/sia-central' +} from '@siafoundation/sia-central-types' export function useSiaCentralBlock( args?: HookArgsSwr diff --git a/libs/sia-central-react/src/useSiaCentralBlockLatest.tsx b/libs/sia-central-react/src/useSiaCentralBlockLatest.tsx index 65456a09b..34c3b3dd4 100644 --- a/libs/sia-central-react/src/useSiaCentralBlockLatest.tsx +++ b/libs/sia-central-react/src/useSiaCentralBlockLatest.tsx @@ -3,7 +3,7 @@ import { HookArgsSwr, useGetSwr, } from '@siafoundation/react-core' -import { api, SiaCentralBlock } from '@siafoundation/sia-central' +import { api, SiaCentralBlock } from '@siafoundation/sia-central-types' type SiaCentralBlockLatestResponse = { message: string diff --git a/libs/sia-central-react/src/useSiaCentralBlocks.tsx b/libs/sia-central-react/src/useSiaCentralBlocks.tsx index 8a3ec1694..026f6572a 100644 --- a/libs/sia-central-react/src/useSiaCentralBlocks.tsx +++ b/libs/sia-central-react/src/useSiaCentralBlocks.tsx @@ -7,7 +7,7 @@ import { api, SiaCentralBlock, SiaCentralBlocksPayload, -} from '@siafoundation/sia-central' +} from '@siafoundation/sia-central-types' type SiaCentralBlocksResposne = { message: string diff --git a/libs/sia-central-react/src/useSiaCentralContract.tsx b/libs/sia-central-react/src/useSiaCentralContract.tsx index 1eb82bb01..e50df6e58 100644 --- a/libs/sia-central-react/src/useSiaCentralContract.tsx +++ b/libs/sia-central-react/src/useSiaCentralContract.tsx @@ -7,7 +7,7 @@ import { api, SiaCentralContractParams, SiaCentralContractResponse, -} from '@siafoundation/sia-central' +} from '@siafoundation/sia-central-types' export function useSiaCentralContract( args?: HookArgsSwr diff --git a/libs/sia-central-react/src/useSiaCentralExchangeRates.tsx b/libs/sia-central-react/src/useSiaCentralExchangeRates.tsx index cea366bb9..b1f0db9a5 100644 --- a/libs/sia-central-react/src/useSiaCentralExchangeRates.tsx +++ b/libs/sia-central-react/src/useSiaCentralExchangeRates.tsx @@ -6,7 +6,7 @@ import { import { api, SiaCentralExchangeRatesResponse, -} from '@siafoundation/sia-central' +} from '@siafoundation/sia-central-types' export function useSiaCentralExchangeRates( args?: HookArgsSwr diff --git a/libs/sia-central-react/src/useSiaCentralHost.tsx b/libs/sia-central-react/src/useSiaCentralHost.tsx index 3693b0acd..a2b95fb99 100644 --- a/libs/sia-central-react/src/useSiaCentralHost.tsx +++ b/libs/sia-central-react/src/useSiaCentralHost.tsx @@ -7,7 +7,7 @@ import { SiaCentralHostResponse, SiaCentralHostParams, api, -} from '@siafoundation/sia-central' +} from '@siafoundation/sia-central-types' export function useSiaCentralHost( args?: HookArgsSwr diff --git a/libs/sia-central-react/src/useSiaCentralHosts.tsx b/libs/sia-central-react/src/useSiaCentralHosts.tsx index 92d16d453..d79182125 100644 --- a/libs/sia-central-react/src/useSiaCentralHosts.tsx +++ b/libs/sia-central-react/src/useSiaCentralHosts.tsx @@ -3,7 +3,7 @@ import { useAppSettings, HookArgsSwr, } from '@siafoundation/react-core' -import { SiaCentralHostsResponse, api } from '@siafoundation/sia-central' +import { SiaCentralHostsResponse, api } from '@siafoundation/sia-central-types' export function useSiaCentralHosts( args?: HookArgsSwr diff --git a/libs/sia-central-react/src/useSiaCentralHostsNetworkAverages.tsx b/libs/sia-central-react/src/useSiaCentralHostsNetworkAverages.tsx index 89ecccb5a..f96eb5552 100644 --- a/libs/sia-central-react/src/useSiaCentralHostsNetworkAverages.tsx +++ b/libs/sia-central-react/src/useSiaCentralHostsNetworkAverages.tsx @@ -6,7 +6,7 @@ import { import { api, SiaCentralHostsNetworkAveragesResponse, -} from '@siafoundation/sia-central' +} from '@siafoundation/sia-central-types' export function useSiaCentralHostsNetworkAverages( args?: HookArgsSwr diff --git a/libs/sia-central-react/src/useSiaCentralHostsNetworkMetrics.tsx b/libs/sia-central-react/src/useSiaCentralHostsNetworkMetrics.tsx index a053a1d2e..82c407094 100644 --- a/libs/sia-central-react/src/useSiaCentralHostsNetworkMetrics.tsx +++ b/libs/sia-central-react/src/useSiaCentralHostsNetworkMetrics.tsx @@ -6,7 +6,7 @@ import { import { api, SiaCentralHostsNetworkMetricsResponse, -} from '@siafoundation/sia-central' +} from '@siafoundation/sia-central-types' export function useSiaCentralHostsNetworkMetrics( args?: HookArgsSwr diff --git a/libs/sia-central-react/src/useSiaCentralSearch.tsx b/libs/sia-central-react/src/useSiaCentralSearch.tsx index 27bfdec07..f245e1117 100644 --- a/libs/sia-central-react/src/useSiaCentralSearch.tsx +++ b/libs/sia-central-react/src/useSiaCentralSearch.tsx @@ -7,7 +7,7 @@ import { api, SiaCentralSearchParams, SiaCentralSearchResponse, -} from '@siafoundation/sia-central' +} from '@siafoundation/sia-central-types' export function useSiaCentralSearch( args?: HookArgsCallback< diff --git a/libs/sia-central-react/src/useSiaCentralTransaction.tsx b/libs/sia-central-react/src/useSiaCentralTransaction.tsx index 3f3ca0e0a..c3fbd312b 100644 --- a/libs/sia-central-react/src/useSiaCentralTransaction.tsx +++ b/libs/sia-central-react/src/useSiaCentralTransaction.tsx @@ -7,7 +7,7 @@ import { api, SiaCentralTransactionParams, SiaCentralTransactionResponse, -} from '@siafoundation/sia-central' +} from '@siafoundation/sia-central-types' export function useSiaCentralTransaction( args?: HookArgsSwr diff --git a/libs/sia-central-types/.babelrc b/libs/sia-central-types/.babelrc new file mode 100644 index 000000000..1ea870ead --- /dev/null +++ b/libs/sia-central-types/.babelrc @@ -0,0 +1,12 @@ +{ + "presets": [ + [ + "@nx/react/babel", + { + "runtime": "automatic", + "useBuiltIns": "usage" + } + ] + ], + "plugins": [] +} diff --git a/libs/sia-central-types/.eslintrc.json b/libs/sia-central-types/.eslintrc.json new file mode 100644 index 000000000..54f8472e1 --- /dev/null +++ b/libs/sia-central-types/.eslintrc.json @@ -0,0 +1,21 @@ +{ + "extends": ["plugin:@nx/react", "../../.eslintrc.json"], + "ignorePatterns": ["!**/*"], + "rules": { + "@nx/dependency-checks": [ + "error", + { + "ignoredFiles": ["libs/sia-central-types/rollup.config.js"] + } + ] + }, + "overrides": [ + { + "files": ["*.json"], + "parser": "jsonc-eslint-parser", + "rules": { + "@nx/dependency-checks": "error" + } + } + ] +} diff --git a/libs/sia-central-types/README.md b/libs/sia-central-types/README.md new file mode 100644 index 000000000..71c8af024 --- /dev/null +++ b/libs/sia-central-types/README.md @@ -0,0 +1,3 @@ +# sia-central-types + +Types for the Sia Central API. diff --git a/libs/sia-central-types/jest.config.ts b/libs/sia-central-types/jest.config.ts new file mode 100644 index 000000000..0656a1299 --- /dev/null +++ b/libs/sia-central-types/jest.config.ts @@ -0,0 +1,17 @@ +/* eslint-disable */ +export default { + displayName: 'sia-central-types', + preset: '../../jest.preset.js', + transform: { + '^(?!.*\\.(js|jsx|ts|tsx|css|json)$)': '@nx/react/plugins/jest', + '^.+\\.[tj]sx?$': [ + 'babel-jest', + { + presets: ['@nx/next/babel'], + plugins: ['@babel/plugin-transform-private-methods'], + }, + ], + }, + moduleFileExtensions: ['ts', 'tsx', 'js', 'jsx'], + coverageDirectory: '../../coverage/libs/sia-central-types', +} diff --git a/libs/sia-central-types/package.json b/libs/sia-central-types/package.json new file mode 100644 index 000000000..9629e88e0 --- /dev/null +++ b/libs/sia-central-types/package.json @@ -0,0 +1,8 @@ +{ + "name": "@siafoundation/sia-central-types", + "description": "Types for the Sia Central API.", + "version": "0.0.0", + "license": "MIT", + "dependencies": {}, + "types": "./src/index.d.ts" +} diff --git a/libs/sia-central-types/project.json b/libs/sia-central-types/project.json new file mode 100644 index 000000000..f9a9886b9 --- /dev/null +++ b/libs/sia-central-types/project.json @@ -0,0 +1,42 @@ +{ + "name": "sia-central-types", + "$schema": "../../node_modules/nx/schemas/project-schema.json", + "sourceRoot": "libs/sia-central-types/src", + "projectType": "library", + "tags": [], + "targets": { + "build": { + "executor": "@nx/rollup:rollup", + "outputs": ["{options.outputPath}"], + "options": { + "outputPath": "dist/libs/sia-central-types", + "tsConfig": "libs/sia-central-types/tsconfig.lib.json", + "project": "libs/sia-central-types/package.json", + "entryFile": "libs/sia-central-types/src/index.ts", + "external": ["react/jsx-runtime"], + "compiler": "tsc", + "outputFileName": "index.js", + "rollupConfig": "libs/sia-central-types/rollup.config.js", + "assets": [ + { + "glob": "libs/sia-central-types/*.md", + "input": ".", + "output": "." + } + ] + }, + "configurations": {} + }, + "lint": { + "executor": "@nx/eslint:lint", + "outputs": ["{options.outputFile}"] + }, + "test": { + "executor": "@nx/jest:jest", + "outputs": ["{workspaceRoot}/coverage/libs/sia-central-types"], + "options": { + "jestConfig": "libs/sia-central-types/jest.config.ts" + } + } + } +} diff --git a/libs/sia-central-types/rollup.config.js b/libs/sia-central-types/rollup.config.js new file mode 100644 index 000000000..3f5e4e997 --- /dev/null +++ b/libs/sia-central-types/rollup.config.js @@ -0,0 +1,18 @@ +// eslint-disable-next-line @typescript-eslint/no-var-requires +const preserveDirectives = require('rollup-plugin-preserve-directives') + +// https://github.com/rollup/rollup/issues/4699#issuecomment-1465302665 +function getRollupOptions(options) { + return { + ...options, + output: { + ...options.output, + preserveModules: true, + format: 'esm', + sourcemap: true, + }, + plugins: options.plugins.concat(preserveDirectives.default()), + } +} + +module.exports = getRollupOptions diff --git a/libs/sia-central/src/siaCentralAddress.tsx b/libs/sia-central-types/src/address.ts similarity index 58% rename from libs/sia-central/src/siaCentralAddress.tsx rename to libs/sia-central-types/src/address.ts index b298e766e..1cbdeaff4 100644 --- a/libs/sia-central/src/siaCentralAddress.tsx +++ b/libs/sia-central-types/src/address.ts @@ -1,5 +1,4 @@ -import { runFetch } from './fetch' -import { SiaCentralSiafundOutput, SiaCentralTransaction, api } from './types' +import { SiaCentralSiafundOutput, SiaCentralTransaction } from './types' export type SiaCentralAddressParams = { id: string @@ -22,15 +21,3 @@ export type SiaCentralAddressResponse = { }[] unspent_siafund_outputs?: SiaCentralSiafundOutput[] } - -export async function getSiaCentralAddress(args: { - params: SiaCentralAddressParams - config?: { - api: string - } -}) { - const { params, config } = args - return runFetch( - `${config?.api || api}/wallet/addresses/${params.id}` - ) -} diff --git a/libs/sia-central-types/src/block.ts b/libs/sia-central-types/src/block.ts new file mode 100644 index 000000000..507946d70 --- /dev/null +++ b/libs/sia-central-types/src/block.ts @@ -0,0 +1,10 @@ +import { SiaCentralBlock } from './types' + +export type SiaCentralBlockParams = { + id: string +} + +export type SiaCentralBlockResponse = { + message: string + block: SiaCentralBlock +} diff --git a/libs/sia-central-types/src/blockLatest.ts b/libs/sia-central-types/src/blockLatest.ts new file mode 100644 index 000000000..774927f4e --- /dev/null +++ b/libs/sia-central-types/src/blockLatest.ts @@ -0,0 +1,6 @@ +import { SiaCentralBlock } from './types' + +export type SiaCentralBlockLatestResponse = { + message: string + block: Omit +} diff --git a/libs/sia-central-types/src/blocks.ts b/libs/sia-central-types/src/blocks.ts new file mode 100644 index 000000000..f87441d86 --- /dev/null +++ b/libs/sia-central-types/src/blocks.ts @@ -0,0 +1,11 @@ +import { SiaCentralBlock } from './types' + +export type SiaCentralBlocksResponse = { + message: string + blocks: SiaCentralBlock[] +} + +export type SiaCentralBlocksPayload = { + block_ids?: number[] + heights?: number[] +} diff --git a/libs/sia-central-types/src/config.ts b/libs/sia-central-types/src/config.ts new file mode 100644 index 000000000..6a7a2d516 --- /dev/null +++ b/libs/sia-central-types/src/config.ts @@ -0,0 +1 @@ +export const api = 'https://api.siacentral.com/v2' diff --git a/libs/sia-central-types/src/contract.ts b/libs/sia-central-types/src/contract.ts new file mode 100644 index 000000000..b5b08ea35 --- /dev/null +++ b/libs/sia-central-types/src/contract.ts @@ -0,0 +1,10 @@ +import { SiaCentralContract } from './types' + +export type SiaCentralContractParams = { + id: string +} + +export type SiaCentralContractResponse = { + message: string + contract: SiaCentralContract +} diff --git a/libs/sia-central/src/siaCentralExchangeRates.tsx b/libs/sia-central-types/src/exchangeRates.ts similarity index 56% rename from libs/sia-central/src/siaCentralExchangeRates.tsx rename to libs/sia-central-types/src/exchangeRates.ts index c015e016b..cb9913bd9 100644 --- a/libs/sia-central/src/siaCentralExchangeRates.tsx +++ b/libs/sia-central-types/src/exchangeRates.ts @@ -1,6 +1,3 @@ -import { runFetch } from './fetch' -import { api } from './types' - export type SiaCentralExchangeRates = { sc: { bch: string @@ -26,14 +23,3 @@ export type SiaCentralExchangeRatesResponse = { rates: SiaCentralExchangeRates timestamp: string } - -export async function getSiaCentralExchangeRates(args?: { - config?: { - api: string - } -}) { - const { config } = args || {} - return runFetch( - `${config?.api || api}/market/exchange-rate?currencies=sc` - ) -} diff --git a/libs/sia-central-types/src/host.ts b/libs/sia-central-types/src/host.ts new file mode 100644 index 000000000..17891589a --- /dev/null +++ b/libs/sia-central-types/src/host.ts @@ -0,0 +1,11 @@ +import { SiaCentralHost } from './types' + +export type SiaCentralHostParams = { + id: string +} + +export type SiaCentralHostResponse = { + message: string + type: string + host: SiaCentralHost +} diff --git a/libs/sia-central-types/src/hosts.ts b/libs/sia-central-types/src/hosts.ts new file mode 100644 index 000000000..d27de8100 --- /dev/null +++ b/libs/sia-central-types/src/hosts.ts @@ -0,0 +1,14 @@ +import { SiaCentralHost } from './types' + +export type SiaCentralHostsParams = { + limit?: number + page?: number +} + +export type SiaCentralHostsResponse = { + message: string + count: number + total: number + type: string + hosts: SiaCentralHost[] +} diff --git a/libs/sia-central-types/src/hostsNetworkAverages.ts b/libs/sia-central-types/src/hostsNetworkAverages.ts new file mode 100644 index 000000000..79fb28dd1 --- /dev/null +++ b/libs/sia-central-types/src/hostsNetworkAverages.ts @@ -0,0 +1,6 @@ +import { SiaCentralNetworkStats } from './types' + +export type SiaCentralHostsNetworkAveragesResponse = { + message: string + type: string +} & SiaCentralNetworkStats diff --git a/libs/sia-central/src/siaCentralHostsNetworkMetrics.tsx b/libs/sia-central-types/src/hostsNetworkMetrics.ts similarity index 53% rename from libs/sia-central/src/siaCentralHostsNetworkMetrics.tsx rename to libs/sia-central-types/src/hostsNetworkMetrics.ts index 28ed742ba..b5a4b8c68 100644 --- a/libs/sia-central/src/siaCentralHostsNetworkMetrics.tsx +++ b/libs/sia-central-types/src/hostsNetworkMetrics.ts @@ -1,5 +1,4 @@ -import { runFetch } from './fetch' -import { SiaCentralNetworkStats, api } from './types' +import { SiaCentralNetworkStats } from './types' export type SiaCentralHostsNetworkMetricsResponse = { message: string @@ -16,14 +15,3 @@ export type SiaCentralHostsNetworkMetricsResponse = { total_hosts: number } } - -export async function getSiaCentralHostsNetworkMetrics(args?: { - config?: { - api: string - } -}) { - const { config } = args || {} - return runFetch( - `${config?.api || api}/hosts/network/metrics` - ) -} diff --git a/libs/sia-central-types/src/index.ts b/libs/sia-central-types/src/index.ts new file mode 100644 index 000000000..7b55efa41 --- /dev/null +++ b/libs/sia-central-types/src/index.ts @@ -0,0 +1,14 @@ +export * from './types' +export * from './config' +export * from './address' +export * from './blockLatest' +export * from './block' +export * from './blocks' +export * from './contract' +export * from './host' +export * from './hosts' +export * from './hostsNetworkAverages' +export * from './hostsNetworkMetrics' +export * from './exchangeRates' +export * from './transaction' +export * from './search' diff --git a/libs/sia-central/src/siaCentralSearch.tsx b/libs/sia-central-types/src/search.ts similarity index 58% rename from libs/sia-central/src/siaCentralSearch.tsx rename to libs/sia-central-types/src/search.ts index 0718f7353..dcb0cdf3d 100644 --- a/libs/sia-central/src/siaCentralSearch.tsx +++ b/libs/sia-central-types/src/search.ts @@ -1,11 +1,9 @@ -import { runFetch } from './fetch' import { SiaCentralBlock, SiaCentralContract, SiaCentralHost, SiaCentralTransaction, SiaCentralUnlockHash, - api, } from './types' export type SiaCentralSearchParams = { @@ -20,15 +18,3 @@ export type SiaCentralSearchResponse = { hosts?: SiaCentralHost[] unlock_hashes?: SiaCentralUnlockHash[] } - -export async function getSiaCentralSearch(args: { - params: SiaCentralSearchParams - config?: { - api: string - } -}) { - const { params, config } = args - return runFetch( - `${config?.api || api}/explorer/search/${params.query}` - ) -} diff --git a/libs/sia-central-types/src/transaction.ts b/libs/sia-central-types/src/transaction.ts new file mode 100644 index 000000000..4253aba1a --- /dev/null +++ b/libs/sia-central-types/src/transaction.ts @@ -0,0 +1,11 @@ +import { SiaCentralTransaction } from './types' + +export type SiaCentralTransactionParams = { + id: string +} + +export type SiaCentralTransactionResponse = { + message: string + type?: 'error' + transaction: SiaCentralTransaction +} diff --git a/libs/sia-central/src/types.tsx b/libs/sia-central-types/src/types.ts similarity index 99% rename from libs/sia-central/src/types.tsx rename to libs/sia-central-types/src/types.ts index 9c048a653..3d8387f55 100644 --- a/libs/sia-central/src/types.tsx +++ b/libs/sia-central-types/src/types.ts @@ -1,5 +1,3 @@ -export const api = 'https://api.siacentral.com/v2' - export type SiaCentralNetworkStats = { settings: { max_download_batch_size: number diff --git a/libs/sia-central-types/tsconfig.json b/libs/sia-central-types/tsconfig.json new file mode 100644 index 000000000..4c089585e --- /dev/null +++ b/libs/sia-central-types/tsconfig.json @@ -0,0 +1,25 @@ +{ + "extends": "../../tsconfig.base.json", + "compilerOptions": { + "jsx": "react-jsx", + "allowJs": true, + "esModuleInterop": true, + "allowSyntheticDefaultImports": true, + "forceConsistentCasingInFileNames": true, + "strict": true, + "noImplicitOverride": true, + "noPropertyAccessFromIndexSignature": true, + "noImplicitReturns": true, + "noFallthroughCasesInSwitch": true + }, + "files": [], + "include": [], + "references": [ + { + "path": "./tsconfig.lib.json" + }, + { + "path": "./tsconfig.spec.json" + } + ] +} diff --git a/libs/sia-central-types/tsconfig.lib.json b/libs/sia-central-types/tsconfig.lib.json new file mode 100644 index 000000000..d73537814 --- /dev/null +++ b/libs/sia-central-types/tsconfig.lib.json @@ -0,0 +1,22 @@ +{ + "extends": "./tsconfig.json", + "compilerOptions": { + "outDir": "../../dist/out-tsc", + "types": [ + "node", + "@nx/react/typings/cssmodule.d.ts", + "@nx/react/typings/image.d.ts" + ] + }, + "exclude": [ + "**/*.spec.ts", + "**/*.test.ts", + "**/*.spec.tsx", + "**/*.test.tsx", + "**/*.spec.js", + "**/*.test.js", + "**/*.spec.jsx", + "**/*.test.jsx" + ], + "include": ["src/**/*.js", "src/**/*.jsx", "src/**/*.ts", "src/**/*.tsx"] +} diff --git a/libs/sia-central-types/tsconfig.spec.json b/libs/sia-central-types/tsconfig.spec.json new file mode 100644 index 000000000..503e9a83d --- /dev/null +++ b/libs/sia-central-types/tsconfig.spec.json @@ -0,0 +1,19 @@ +{ + "extends": "./tsconfig.json", + "compilerOptions": { + "outDir": "../../dist/out-tsc", + "module": "commonjs", + "types": ["jest", "node"] + }, + "include": [ + "src/**/*.test.ts", + "src/**/*.spec.ts", + "src/**/*.test.tsx", + "src/**/*.spec.tsx", + "src/**/*.test.js", + "src/**/*.spec.js", + "src/**/*.test.jsx", + "src/**/*.spec.jsx", + "src/**/*.d.ts" + ] +} diff --git a/libs/sia-central/README.md b/libs/sia-central/README.md deleted file mode 100644 index c2dc55cb3..000000000 --- a/libs/sia-central/README.md +++ /dev/null @@ -1,7 +0,0 @@ -# sia-central - -Methods and types for interacting with the Sia Central API. - -## Running unit tests - -Run `nx test sia-central` to execute the unit tests via [Jest](https://jestjs.io). diff --git a/libs/sia-central/src/index.ts b/libs/sia-central/src/index.ts deleted file mode 100644 index 1e542e702..000000000 --- a/libs/sia-central/src/index.ts +++ /dev/null @@ -1,13 +0,0 @@ -export * from './types' -export * from './siaCentralAddress' -export * from './siaCentralBlockLatest' -export * from './siaCentralBlock' -export * from './siaCentralBlocks' -export * from './siaCentralContract' -export * from './siaCentralHost' -export * from './siaCentralHosts' -export * from './siaCentralHostsNetworkAverages' -export * from './siaCentralHostsNetworkMetrics' -export * from './siaCentralExchangeRates' -export * from './siaCentralTransaction' -export * from './siaCentralSearch' diff --git a/libs/units/package.json b/libs/units/package.json index 4cfdd79d7..5125403e4 100644 --- a/libs/units/package.json +++ b/libs/units/package.json @@ -3,14 +3,12 @@ "description": "Methods and types for interacting with the Sia Central API.", "version": "3.0.0", "license": "MIT", - "peerDependencies": { - "@siafoundation/sia-central": "^0.3.3", - "@siafoundation/react-core": "^1.1.0", - "bignumber.js": "^9.0.2" - }, "dependencies": { + "@siafoundation/react-core": "^1.1.0", + "bignumber.js": "^9.0.2", "@technically/lodash": "^4.17.0", - "blakejs": "^1.2.1" + "blakejs": "^1.2.1", + "@siafoundation/sia-central-types": "0.0.0" }, "types": "./src/index.d.ts" } diff --git a/libs/units/src/storage.ts b/libs/units/src/storage.ts index c3d6a64f0..9327abfbe 100644 --- a/libs/units/src/storage.ts +++ b/libs/units/src/storage.ts @@ -1,6 +1,6 @@ import { TBToBytes } from './bytes' import { monthsToBlocks } from './blockTime' -import { SiaCentralHost } from '@siafoundation/sia-central' +import { SiaCentralHost } from '@siafoundation/sia-central-types' import BigNumber from 'bignumber.js' import { humanSiacoin } from './currency' import { humanBytes, humanSpeed } from './humanUnits' diff --git a/tsconfig.base.json b/tsconfig.base.json index d06c15812..b78eaf5e7 100644 --- a/tsconfig.base.json +++ b/tsconfig.base.json @@ -25,19 +25,22 @@ "@siafoundation/react-icons": ["libs/react-icons/src/index.ts"], "@siafoundation/renterd-types": ["libs/renterd-types/src/index.ts"], "@siafoundation/renterd-react": ["libs/renterd-react/src/index.ts"], - "@siafoundation/sia-central-react": [ - "libs/sia-central-react/src/index.ts" - ], "@siafoundation/walletd-types": ["libs/walletd-types/src/index.ts"], "@siafoundation/walletd-react": ["libs/walletd-react/src/index.ts"], // "buildLibsFromSource": false does not work with the next executor // this is a very annoying workaround "@siafoundation/sdk": ["dist/libs/sdk/index.esm.js"], - "@siafoundation/sia-central": ["libs/sia-central/src/index.ts"], + "@siafoundation/sia-central-types": [ + "libs/sia-central-types/src/index.ts" + ], + "@siafoundation/sia-central-js": ["libs/sia-central-js/src/index.ts"], + "@siafoundation/sia-central-react": [ + "libs/sia-central-react/src/index.ts" + ], + "@siafoundation/sia-central-mock": ["libs/sia-central-mock/src/index.ts"], "@siafoundation/types": ["libs/types/src/index.ts"], "@siafoundation/units": ["libs/units/src/index.ts"], - "@siafoundation/walletd-mock": ["libs/walletd-mock/src/index.ts"], - "@siafoundation/sia-central-mock": ["libs/sia-central-mock/src/index.ts"] + "@siafoundation/walletd-mock": ["libs/walletd-mock/src/index.ts"] } }, "exclude": ["node_modules", "tmp"]