Merge branch 'main' into develop
This commit is contained in:
		
						commit
						cebbdb4ee7
					
				| @ -1,5 +1,8 @@ | ||||
| import type { ChainIdMapping } from './external-chain'; | ||||
| import { SUPPORTED_CHAIN_IDS, SUPPORTED_CHAIN_LABELS } from './external-chain'; | ||||
| import type { ChainIdMapping } from '@vegaprotocol/environment'; | ||||
| import { | ||||
|   SUPPORTED_CHAIN_IDS, | ||||
|   SUPPORTED_CHAIN_LABELS, | ||||
| } from '@vegaprotocol/environment'; | ||||
| 
 | ||||
| export const SUPPORTED_CHAIN_ICON_URLS: ChainIdMapping = { | ||||
|   '1': '/assets/chain-eth-logo.svg', | ||||
|  | ||||
| @ -1,5 +1,5 @@ | ||||
| import Hash from '../hash'; | ||||
| import { getExternalExplorerLink } from './external-chain'; | ||||
| import { getExternalExplorerLink } from '@vegaprotocol/environment'; | ||||
| import { ExternalChainIcon } from './external-chain-icon'; | ||||
| 
 | ||||
| export enum EthExplorerLinkTypes { | ||||
| @ -23,7 +23,7 @@ export const ExternalExplorerLink = ({ | ||||
|   code = false, | ||||
|   ...props | ||||
| }: ExternalExplorerLinkProps) => { | ||||
|   const link = `${getExternalExplorerLink(chain, type)}/${type}/${id}${ | ||||
|   const link = `${getExternalExplorerLink(chain)}/${type}/${id}${ | ||||
|     code ? '#code' : '' | ||||
|   }`;
 | ||||
|   return ( | ||||
|  | ||||
| @ -4,7 +4,7 @@ import { | ||||
|   ExternalExplorerLink, | ||||
|   EthExplorerLinkTypes, | ||||
| } from '../../../links/external-explorer-link/external-explorer-link'; | ||||
| import { getExternalChainLabel } from '../../../links/external-explorer-link/external-chain'; | ||||
| import { getExternalChainLabel } from '@vegaprotocol/environment'; | ||||
| import type { components } from '../../../../../types/explorer'; | ||||
| import { defaultAbiCoder, base64 } from 'ethers/lib/utils'; | ||||
| import { BigNumber } from 'ethers'; | ||||
|  | ||||
| @ -4,7 +4,7 @@ import { | ||||
|   ExternalExplorerLink, | ||||
|   EthExplorerLinkTypes, | ||||
| } from '../../../components/links/external-explorer-link/external-explorer-link'; | ||||
| import { getExternalChainLabel } from '../../../components/links/external-explorer-link/external-chain'; | ||||
| import { getExternalChainLabel } from '@vegaprotocol/environment'; | ||||
| import { t } from 'i18next'; | ||||
| 
 | ||||
| interface OracleDetailsEthSourceProps { | ||||
|  | ||||
| @ -3,8 +3,6 @@ export const VALIDATOR_LOGO_MAP: { [key: string]: string } = { | ||||
|     'https://pbs.twimg.com/profile_images/1586047492629712897/ZVMWBE94_400x400.jpg', | ||||
|   efbdf943443bd7595e83b0d7e88f37b7932d487d1b94aab3d004997273bb43fc: | ||||
|     'https://pbs.twimg.com/profile_images/1026823609979949057/3e-LCHHm_400x400.jpg', | ||||
|   '126751c5830b50d39eb85412fb2964f46338cce6946ff455b73f1b1be3f5e8cc': | ||||
|     'https://pbs.twimg.com/profile_images/1228627868542029824/9aoaLiIx_400x400.jpg', | ||||
|   '43697a3e911d8b70c0ce672adde17a5c38ca8f6a0486bf85ed0546e1b9a82887': | ||||
|     'https://pbs.twimg.com/profile_images/1352167987478843392/XzX82gIb_400x400.jpg', | ||||
|   ac735acc9ab11cf1d8c59c2df2107e00092b4ac96451cb137a1629af5b66242a: | ||||
|  | ||||
| @ -0,0 +1 @@ | ||||
| export { ProposalsList } from './proposals-list'; | ||||
| @ -6,7 +6,7 @@ import { | ||||
|   ActionsDropdown, | ||||
| } from '@vegaprotocol/ui-toolkit'; | ||||
| import { DApp, TOKEN_PROPOSAL, useLinks } from '@vegaprotocol/environment'; | ||||
| import { useT } from '../use-t'; | ||||
| import { useT } from '../../../lib/use-t'; | ||||
| 
 | ||||
| export const ProposalActionsDropdown = ({ id }: { id: string }) => { | ||||
|   const t = useT(); | ||||
| @ -18,6 +18,7 @@ export const ProposalActionsDropdown = ({ id }: { id: string }) => { | ||||
|         <Link | ||||
|           href={linkCreator(TOKEN_PROPOSAL.replace(':id', id))} | ||||
|           target="_blank" | ||||
|           className="flex items-center gap-2" | ||||
|         > | ||||
|           <VegaIcon name={VegaIconNames.OPEN_EXTERNAL} size={16} /> | ||||
|           {t('View proposal')} | ||||
| @ -1,75 +1,42 @@ | ||||
| import { render, screen, waitFor, within } from '@testing-library/react'; | ||||
| import merge from 'lodash/merge'; | ||||
| import type { MockedResponse } from '@apollo/client/testing'; | ||||
| import { MockedProvider } from '@apollo/client/testing'; | ||||
| import { ProposalsList } from './proposals-list'; | ||||
| import * as Types from '@vegaprotocol/types'; | ||||
| import { createProposalListFieldsFragment } from '../../lib/proposals-data-provider/proposals.mock'; | ||||
| import type { ProposalsListQuery } from '../../lib'; | ||||
| import { ProposalsListDocument } from '../../lib'; | ||||
| import type { PartialDeep } from 'type-fest'; | ||||
| import { MarketState } from '@vegaprotocol/types'; | ||||
| import { createMarketFragment } from '@vegaprotocol/mock'; | ||||
| import { | ||||
|   type MarketsQuery, | ||||
|   MarketsDocument, | ||||
|   type MarketsQueryVariables, | ||||
| } from '@vegaprotocol/markets'; | ||||
| 
 | ||||
| const parentMarketName = 'Parent Market Name'; | ||||
| const ParentMarketCell = () => <span>{parentMarketName}</span>; | ||||
| 
 | ||||
| describe('ProposalsList', () => { | ||||
|   const rowContainerSelector = '.ag-center-cols-container'; | ||||
| 
 | ||||
|   const createProposalsMock = (override?: PartialDeep<ProposalsListQuery>) => { | ||||
|     const defaultProposalEdges = [ | ||||
|       { | ||||
|         __typename: 'ProposalEdge' as const, | ||||
|         node: createProposalListFieldsFragment({ | ||||
|           id: 'id-1', | ||||
|           state: Types.ProposalState.STATE_OPEN, | ||||
|         }), | ||||
|       }, | ||||
|       { | ||||
|         __typename: 'ProposalEdge' as const, | ||||
|         node: createProposalListFieldsFragment({ | ||||
|           id: 'id-2', | ||||
|           state: Types.ProposalState.STATE_PASSED, | ||||
|         }), | ||||
|       }, | ||||
|       { | ||||
|         __typename: 'ProposalEdge' as const, | ||||
|         node: createProposalListFieldsFragment({ | ||||
|           id: 'id-3', | ||||
|           state: Types.ProposalState.STATE_WAITING_FOR_NODE_VOTE, | ||||
|         }), | ||||
|       }, | ||||
|     ]; | ||||
|     const data = merge( | ||||
|       { | ||||
|         proposalsConnection: { | ||||
|           __typename: 'ProposalsConnection' as const, | ||||
|           edges: defaultProposalEdges, | ||||
|         }, | ||||
|       }, | ||||
|       override | ||||
|     ); | ||||
| 
 | ||||
|     const mock: MockedResponse<ProposalsListQuery> = { | ||||
|       request: { | ||||
|         query: ProposalsListDocument, | ||||
|         variables: { | ||||
|           proposalType: Types.ProposalType.TYPE_NEW_MARKET, | ||||
|         }, | ||||
|       }, | ||||
|       result: { | ||||
|         data, | ||||
|       }, | ||||
|     }; | ||||
| 
 | ||||
|     return mock; | ||||
|   }; | ||||
| 
 | ||||
|   beforeEach(() => { | ||||
|     jest.clearAllMocks(); | ||||
|   const market = createMarketFragment({ | ||||
|     state: MarketState.STATE_PROPOSED, | ||||
|   }); | ||||
| 
 | ||||
|   it('should be properly rendered', async () => { | ||||
|     const mock = createProposalsMock(); | ||||
|     const mock: MockedResponse<MarketsQuery, MarketsQueryVariables> = { | ||||
|       request: { | ||||
|         query: MarketsDocument, | ||||
|       }, | ||||
|       result: { | ||||
|         data: { | ||||
|           marketsConnection: { | ||||
|             edges: [ | ||||
|               { | ||||
|                 node: market, | ||||
|               }, | ||||
|             ], | ||||
|           }, | ||||
|         }, | ||||
|       }, | ||||
|     }; | ||||
| 
 | ||||
|     render( | ||||
|       <MockedProvider mocks={[mock]}> | ||||
|         <ProposalsList cellRenderers={{ ParentMarketCell }} /> | ||||
| @ -102,30 +69,25 @@ describe('ProposalsList', () => { | ||||
| 
 | ||||
|     expect(await container.findAllByRole('row')).toHaveLength( | ||||
|       // @ts-ignore data is mocked
 | ||||
|       mock?.result?.data.proposalsConnection.edges.length | ||||
|       mock?.result?.data.marketsConnection.edges.length | ||||
|     ); | ||||
| 
 | ||||
|     expect( | ||||
|       container.getAllByRole('gridcell', { | ||||
|         name: (_, element) => | ||||
|           element.getAttribute('col-id') === | ||||
|           'terms.change.successorConfiguration.parentMarketId', | ||||
|           element.getAttribute('col-id') === 'parentMarketID', | ||||
|       })[0] | ||||
|     ).toHaveTextContent(parentMarketName); | ||||
|   }); | ||||
| 
 | ||||
|   it('empty response should causes no data message display', async () => { | ||||
|     const mock: MockedResponse<ProposalsListQuery> = { | ||||
|     const mock: MockedResponse<MarketsQuery, MarketsQueryVariables> = { | ||||
|       request: { | ||||
|         query: ProposalsListDocument, | ||||
|         variables: { | ||||
|           proposalType: Types.ProposalType.TYPE_NEW_MARKET, | ||||
|         }, | ||||
|         query: MarketsDocument, | ||||
|       }, | ||||
|       result: { | ||||
|         data: { | ||||
|           proposalsConnection: { | ||||
|             __typename: 'ProposalsConnection', | ||||
|           marketsConnection: { | ||||
|             edges: [], | ||||
|           }, | ||||
|         }, | ||||
| @ -0,0 +1,37 @@ | ||||
| import type { FC } from 'react'; | ||||
| import { AgGrid } from '@vegaprotocol/datagrid'; | ||||
| import { useProposedMarketsList } from '@vegaprotocol/markets'; | ||||
| import { type ProposalListFieldsFragment } from '@vegaprotocol/proposals'; | ||||
| import { useColumnDefs } from './use-column-defs'; | ||||
| import { useT } from '../../../lib/use-t'; | ||||
| 
 | ||||
| const defaultColDef = { | ||||
|   sortable: true, | ||||
|   filter: true, | ||||
|   resizable: true, | ||||
|   filterParams: { buttons: ['reset'] }, | ||||
| }; | ||||
| 
 | ||||
| interface ProposalListProps { | ||||
|   cellRenderers: { | ||||
|     [name: string]: FC<{ value: string; data: ProposalListFieldsFragment }>; | ||||
|   }; | ||||
| } | ||||
| 
 | ||||
| export const ProposalsList = ({ cellRenderers }: ProposalListProps) => { | ||||
|   const t = useT(); | ||||
|   const { data } = useProposedMarketsList(); | ||||
|   const columnDefs = useColumnDefs(); | ||||
| 
 | ||||
|   return ( | ||||
|     <AgGrid | ||||
|       columnDefs={columnDefs} | ||||
|       rowData={data} | ||||
|       defaultColDef={defaultColDef} | ||||
|       getRowId={({ data }) => data.id} | ||||
|       overlayNoRowsTemplate={t('No proposed markets')} | ||||
|       components={cellRenderers} | ||||
|       rowHeight={45} | ||||
|     /> | ||||
|   ); | ||||
| }; | ||||
| @ -13,12 +13,16 @@ import type { | ||||
|   VegaValueFormatterParams, | ||||
| } from '@vegaprotocol/datagrid'; | ||||
| import { | ||||
|   ProposalProductTypeShortName, | ||||
|   ProposalStateMapping, | ||||
|   MarketStateMapping, | ||||
|   ProductTypeMapping, | ||||
|   ProductTypeShortName, | ||||
| } from '@vegaprotocol/types'; | ||||
| import type { ProposalListFieldsFragment } from '../../lib/proposals-data-provider/__generated__/Proposals'; | ||||
| import { ProposalActionsDropdown } from '../proposal-actions-dropdown'; | ||||
| import { useT } from '../../use-t'; | ||||
| import { ProposalActionsDropdown } from './proposal-actions-dropdown'; | ||||
| import { | ||||
|   type MarketFieldsFragment, | ||||
|   getProductType, | ||||
| } from '@vegaprotocol/markets'; | ||||
| import { useT } from '../../../lib/use-t'; | ||||
| 
 | ||||
| export const useColumnDefs = () => { | ||||
|   const t = useT(); | ||||
| @ -28,7 +32,7 @@ export const useColumnDefs = () => { | ||||
|       { | ||||
|         colId: 'market', | ||||
|         headerName: t('Market'), | ||||
|         field: 'terms.change.instrument.code', | ||||
|         field: 'tradableInstrument.instrument.code', | ||||
|         pinned: true, | ||||
|         cellStyle: { lineHeight: '14px' }, | ||||
|         cellRenderer: ({ | ||||
| @ -36,20 +40,10 @@ export const useColumnDefs = () => { | ||||
|           data, | ||||
|         }: { | ||||
|           value: string; | ||||
|           data: ProposalListFieldsFragment; | ||||
|           data: MarketFieldsFragment; | ||||
|         }) => { | ||||
|           if (!value || !data) return '-'; | ||||
| 
 | ||||
|           const getProductType = (data: ProposalListFieldsFragment) => { | ||||
|             if ( | ||||
|               data.terms.__typename === 'ProposalTerms' && | ||||
|               data.terms.change.__typename === 'NewMarket' | ||||
|             ) { | ||||
|               return data.terms.change.instrument.product?.__typename; | ||||
|             } | ||||
|             return undefined; | ||||
|           }; | ||||
| 
 | ||||
|           const productType = getProductType(data); | ||||
|           return ( | ||||
|             productType && ( | ||||
| @ -57,10 +51,10 @@ export const useColumnDefs = () => { | ||||
|                 primary={value} | ||||
|                 secondary={ | ||||
|                   <span | ||||
|                     title={ProposalProductTypeShortName[productType]} | ||||
|                     title={ProductTypeMapping[productType]} | ||||
|                     className="uppercase" | ||||
|                   > | ||||
|                     {ProposalProductTypeShortName[productType]} | ||||
|                     {ProductTypeShortName[productType]} | ||||
|                   </span> | ||||
|                 } | ||||
|               /> | ||||
| @ -71,7 +65,7 @@ export const useColumnDefs = () => { | ||||
|       { | ||||
|         colId: 'asset', | ||||
|         headerName: t('Settlement asset'), | ||||
|         field: 'terms.change.instrument.product.settlementAsset.symbol', | ||||
|         field: 'tradableInstrument.instrument.product.settlementAsset.symbol', | ||||
|       }, | ||||
|       { | ||||
|         colId: 'state', | ||||
| @ -79,39 +73,42 @@ export const useColumnDefs = () => { | ||||
|         field: 'state', | ||||
|         valueFormatter: ({ | ||||
|           value, | ||||
|         }: VegaValueFormatterParams<ProposalListFieldsFragment, 'state'>) => | ||||
|           value ? ProposalStateMapping[value] : '-', | ||||
|         }: VegaValueFormatterParams<MarketFieldsFragment, 'state'>) => { | ||||
|           return value ? MarketStateMapping[value] : '-'; | ||||
|         }, | ||||
|         filter: SetFilter, | ||||
|         filterParams: { | ||||
|           set: ProposalStateMapping, | ||||
|           set: MarketStateMapping, | ||||
|         }, | ||||
|       }, | ||||
|       { | ||||
|         headerName: t('Parent market'), | ||||
|         field: 'terms.change.successorConfiguration.parentMarketId', | ||||
|         field: 'parentMarketID', | ||||
|         cellRenderer: 'ParentMarketCell', | ||||
|       }, | ||||
|       { | ||||
|         colId: 'closing-date', | ||||
|         headerName: t('Closing date'), | ||||
|         field: 'terms.closingDatetime', | ||||
|         field: 'marketTimestamps.pending', | ||||
|         valueFormatter: ({ | ||||
|           value, | ||||
|         }: VegaValueFormatterParams< | ||||
|           ProposalListFieldsFragment, | ||||
|           'terms.closingDatetime' | ||||
|         >) => (value ? getDateTimeFormat().format(new Date(value)) : '-'), | ||||
|           MarketFieldsFragment, | ||||
|           'marketTimestamps.pending' | ||||
|         >) => { | ||||
|           return value ? getDateTimeFormat().format(new Date(value)) : '-'; | ||||
|         }, | ||||
|         filter: DateRangeFilter, | ||||
|       }, | ||||
|       { | ||||
|         colId: 'enactment-date', | ||||
|         headerName: t('Enactment date'), | ||||
|         field: 'terms.enactmentDatetime', | ||||
|         field: 'marketTimestamps.open', | ||||
|         valueFormatter: ({ | ||||
|           value, | ||||
|         }: VegaValueFormatterParams< | ||||
|           ProposalListFieldsFragment, | ||||
|           'terms.enactmentDatetime' | ||||
|           MarketFieldsFragment, | ||||
|           'marketTimestamps.open' | ||||
|         >) => (value ? getDateTimeFormat().format(new Date(value)) : '-'), | ||||
|         filter: DateRangeFilter, | ||||
|       }, | ||||
| @ -120,10 +117,10 @@ export const useColumnDefs = () => { | ||||
|         ...COL_DEFS.actions, | ||||
|         cellRenderer: ({ | ||||
|           data, | ||||
|         }: VegaICellRendererParams<ProposalListFieldsFragment>) => { | ||||
|           if (!data?.id) return null; | ||||
|         }: VegaICellRendererParams<MarketFieldsFragment>) => { | ||||
|           if (!data?.marketProposal?.id) return null; | ||||
| 
 | ||||
|           return <ProposalActionsDropdown id={data.id} />; | ||||
|           return <ProposalActionsDropdown id={data.marketProposal.id} />; | ||||
|         }, | ||||
|       }, | ||||
|     ]); | ||||
| @ -1,4 +1,4 @@ | ||||
| import { ProposalsList } from '@vegaprotocol/proposals'; | ||||
| import { ProposalsList } from './proposals-list'; | ||||
| import { ParentMarketCell } from './parent-market-cell'; | ||||
| 
 | ||||
| const cellRenderers = { | ||||
|  | ||||
| @ -63,7 +63,11 @@ export const useMarketSelectorList = ({ | ||||
|         [ | ||||
|           (m) => { | ||||
|             if (!m.candles?.length) return 0; | ||||
|             return Number(priceChangePercentage(m.candles.map((c) => c.close))); | ||||
|             return Number( | ||||
|               priceChangePercentage( | ||||
|                 m.candles.filter((c) => c.close !== '').map((c) => c.close) | ||||
|               ) | ||||
|             ); | ||||
|           }, | ||||
|         ], | ||||
|         [dir] | ||||
|  | ||||
							
								
								
									
										262
									
								
								apps/trading/e2e/poetry.lock
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										262
									
								
								apps/trading/e2e/poetry.lock
									
									
									
										generated
									
									
									
								
							| @ -1,4 +1,4 @@ | ||||
| # This file is automatically @generated by Poetry 1.6.1 and should not be changed by hand. | ||||
| # This file is automatically @generated by Poetry 1.8.2 and should not be changed by hand. | ||||
| 
 | ||||
| [[package]] | ||||
| name = "certifi" | ||||
| @ -341,135 +341,135 @@ test = ["objgraph", "psutil"] | ||||
| 
 | ||||
| [[package]] | ||||
| name = "grpcio" | ||||
| version = "1.62.0" | ||||
| version = "1.62.1" | ||||
| description = "HTTP/2-based RPC framework" | ||||
| optional = false | ||||
| python-versions = ">=3.7" | ||||
| files = [ | ||||
|     {file = "grpcio-1.62.0-cp310-cp310-linux_armv7l.whl", hash = "sha256:136ffd79791b1eddda8d827b607a6285474ff8a1a5735c4947b58c481e5e4271"}, | ||||
|     {file = "grpcio-1.62.0-cp310-cp310-macosx_12_0_universal2.whl", hash = "sha256:d6a56ba703be6b6267bf19423d888600c3f574ac7c2cc5e6220af90662a4d6b0"}, | ||||
|     {file = "grpcio-1.62.0-cp310-cp310-manylinux_2_17_aarch64.whl", hash = "sha256:4cd356211579043fce9f52acc861e519316fff93980a212c8109cca8f47366b6"}, | ||||
|     {file = "grpcio-1.62.0-cp310-cp310-manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:e803e9b58d8f9b4ff0ea991611a8d51b31c68d2e24572cd1fe85e99e8cc1b4f8"}, | ||||
|     {file = "grpcio-1.62.0-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:f4c04fe33039b35b97c02d2901a164bbbb2f21fb9c4e2a45a959f0b044c3512c"}, | ||||
|     {file = "grpcio-1.62.0-cp310-cp310-musllinux_1_1_i686.whl", hash = "sha256:95370c71b8c9062f9ea033a0867c4c73d6f0ff35113ebd2618171ec1f1e903e0"}, | ||||
|     {file = "grpcio-1.62.0-cp310-cp310-musllinux_1_1_x86_64.whl", hash = "sha256:c912688acc05e4ff012c8891803659d6a8a8b5106f0f66e0aed3fb7e77898fa6"}, | ||||
|     {file = "grpcio-1.62.0-cp310-cp310-win32.whl", hash = "sha256:821a44bd63d0f04e33cf4ddf33c14cae176346486b0df08b41a6132b976de5fc"}, | ||||
|     {file = "grpcio-1.62.0-cp310-cp310-win_amd64.whl", hash = "sha256:81531632f93fece32b2762247c4c169021177e58e725494f9a746ca62c83acaa"}, | ||||
|     {file = "grpcio-1.62.0-cp311-cp311-linux_armv7l.whl", hash = "sha256:3fa15850a6aba230eed06b236287c50d65a98f05054a0f01ccedf8e1cc89d57f"}, | ||||
|     {file = "grpcio-1.62.0-cp311-cp311-macosx_10_10_universal2.whl", hash = "sha256:36df33080cd7897623feff57831eb83c98b84640b016ce443305977fac7566fb"}, | ||||
|     {file = "grpcio-1.62.0-cp311-cp311-manylinux_2_17_aarch64.whl", hash = "sha256:7a195531828b46ea9c4623c47e1dc45650fc7206f8a71825898dd4c9004b0928"}, | ||||
|     {file = "grpcio-1.62.0-cp311-cp311-manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:ab140a3542bbcea37162bdfc12ce0d47a3cda3f2d91b752a124cc9fe6776a9e2"}, | ||||
|     {file = "grpcio-1.62.0-cp311-cp311-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:7f9d6c3223914abb51ac564dc9c3782d23ca445d2864321b9059d62d47144021"}, | ||||
|     {file = "grpcio-1.62.0-cp311-cp311-musllinux_1_1_i686.whl", hash = "sha256:fbe0c20ce9a1cff75cfb828b21f08d0a1ca527b67f2443174af6626798a754a4"}, | ||||
|     {file = "grpcio-1.62.0-cp311-cp311-musllinux_1_1_x86_64.whl", hash = "sha256:38f69de9c28c1e7a8fd24e4af4264726637b72f27c2099eaea6e513e7142b47e"}, | ||||
|     {file = "grpcio-1.62.0-cp311-cp311-win32.whl", hash = "sha256:ce1aafdf8d3f58cb67664f42a617af0e34555fe955450d42c19e4a6ad41c84bd"}, | ||||
|     {file = "grpcio-1.62.0-cp311-cp311-win_amd64.whl", hash = "sha256:eef1d16ac26c5325e7d39f5452ea98d6988c700c427c52cbc7ce3201e6d93334"}, | ||||
|     {file = "grpcio-1.62.0-cp312-cp312-linux_armv7l.whl", hash = "sha256:8aab8f90b2a41208c0a071ec39a6e5dbba16fd827455aaa070fec241624ccef8"}, | ||||
|     {file = "grpcio-1.62.0-cp312-cp312-macosx_10_10_universal2.whl", hash = "sha256:62aa1659d8b6aad7329ede5d5b077e3d71bf488d85795db517118c390358d5f6"}, | ||||
|     {file = "grpcio-1.62.0-cp312-cp312-manylinux_2_17_aarch64.whl", hash = "sha256:0d7ae7fc7dbbf2d78d6323641ded767d9ec6d121aaf931ec4a5c50797b886532"}, | ||||
|     {file = "grpcio-1.62.0-cp312-cp312-manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:f359d635ee9428f0294bea062bb60c478a8ddc44b0b6f8e1f42997e5dc12e2ee"}, | ||||
|     {file = "grpcio-1.62.0-cp312-cp312-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:77d48e5b1f8f4204889f1acf30bb57c30378e17c8d20df5acbe8029e985f735c"}, | ||||
|     {file = "grpcio-1.62.0-cp312-cp312-musllinux_1_1_i686.whl", hash = "sha256:662d3df5314ecde3184cf87ddd2c3a66095b3acbb2d57a8cada571747af03873"}, | ||||
|     {file = "grpcio-1.62.0-cp312-cp312-musllinux_1_1_x86_64.whl", hash = "sha256:92cdb616be44c8ac23a57cce0243af0137a10aa82234f23cd46e69e115071388"}, | ||||
|     {file = "grpcio-1.62.0-cp312-cp312-win32.whl", hash = "sha256:0b9179478b09ee22f4a36b40ca87ad43376acdccc816ce7c2193a9061bf35701"}, | ||||
|     {file = "grpcio-1.62.0-cp312-cp312-win_amd64.whl", hash = "sha256:614c3ed234208e76991992342bab725f379cc81c7dd5035ee1de2f7e3f7a9842"}, | ||||
|     {file = "grpcio-1.62.0-cp37-cp37m-linux_armv7l.whl", hash = "sha256:7e1f51e2a460b7394670fdb615e26d31d3260015154ea4f1501a45047abe06c9"}, | ||||
|     {file = "grpcio-1.62.0-cp37-cp37m-macosx_10_10_universal2.whl", hash = "sha256:bcff647e7fe25495e7719f779cc219bbb90b9e79fbd1ce5bda6aae2567f469f2"}, | ||||
|     {file = "grpcio-1.62.0-cp37-cp37m-manylinux_2_17_aarch64.whl", hash = "sha256:56ca7ba0b51ed0de1646f1735154143dcbdf9ec2dbe8cc6645def299bb527ca1"}, | ||||
|     {file = "grpcio-1.62.0-cp37-cp37m-manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:2e84bfb2a734e4a234b116be208d6f0214e68dcf7804306f97962f93c22a1839"}, | ||||
|     {file = "grpcio-1.62.0-cp37-cp37m-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:2c1488b31a521fbba50ae86423f5306668d6f3a46d124f7819c603979fc538c4"}, | ||||
|     {file = "grpcio-1.62.0-cp37-cp37m-musllinux_1_1_i686.whl", hash = "sha256:98d8f4eb91f1ce0735bf0b67c3b2a4fea68b52b2fd13dc4318583181f9219b4b"}, | ||||
|     {file = "grpcio-1.62.0-cp37-cp37m-musllinux_1_1_x86_64.whl", hash = "sha256:b3d3d755cfa331d6090e13aac276d4a3fb828bf935449dc16c3d554bf366136b"}, | ||||
|     {file = "grpcio-1.62.0-cp37-cp37m-win_amd64.whl", hash = "sha256:a33f2bfd8a58a02aab93f94f6c61279be0f48f99fcca20ebaee67576cd57307b"}, | ||||
|     {file = "grpcio-1.62.0-cp38-cp38-linux_armv7l.whl", hash = "sha256:5e709f7c8028ce0443bddc290fb9c967c1e0e9159ef7a030e8c21cac1feabd35"}, | ||||
|     {file = "grpcio-1.62.0-cp38-cp38-macosx_10_10_universal2.whl", hash = "sha256:2f3d9a4d0abb57e5f49ed5039d3ed375826c2635751ab89dcc25932ff683bbb6"}, | ||||
|     {file = "grpcio-1.62.0-cp38-cp38-manylinux_2_17_aarch64.whl", hash = "sha256:62ccb92f594d3d9fcd00064b149a0187c246b11e46ff1b7935191f169227f04c"}, | ||||
|     {file = "grpcio-1.62.0-cp38-cp38-manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:921148f57c2e4b076af59a815467d399b7447f6e0ee10ef6d2601eb1e9c7f402"}, | ||||
|     {file = "grpcio-1.62.0-cp38-cp38-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:f897b16190b46bc4d4aaf0a32a4b819d559a37a756d7c6b571e9562c360eed72"}, | ||||
|     {file = "grpcio-1.62.0-cp38-cp38-musllinux_1_1_i686.whl", hash = "sha256:1bc8449084fe395575ed24809752e1dc4592bb70900a03ca42bf236ed5bf008f"}, | ||||
|     {file = "grpcio-1.62.0-cp38-cp38-musllinux_1_1_x86_64.whl", hash = "sha256:81d444e5e182be4c7856cd33a610154fe9ea1726bd071d07e7ba13fafd202e38"}, | ||||
|     {file = "grpcio-1.62.0-cp38-cp38-win32.whl", hash = "sha256:88f41f33da3840b4a9bbec68079096d4caf629e2c6ed3a72112159d570d98ebe"}, | ||||
|     {file = "grpcio-1.62.0-cp38-cp38-win_amd64.whl", hash = "sha256:fc2836cb829895ee190813446dce63df67e6ed7b9bf76060262c55fcd097d270"}, | ||||
|     {file = "grpcio-1.62.0-cp39-cp39-linux_armv7l.whl", hash = "sha256:fcc98cff4084467839d0a20d16abc2a76005f3d1b38062464d088c07f500d170"}, | ||||
|     {file = "grpcio-1.62.0-cp39-cp39-macosx_10_10_universal2.whl", hash = "sha256:0d3dee701e48ee76b7d6fbbba18ba8bc142e5b231ef7d3d97065204702224e0e"}, | ||||
|     {file = "grpcio-1.62.0-cp39-cp39-manylinux_2_17_aarch64.whl", hash = "sha256:b7a6be562dd18e5d5bec146ae9537f20ae1253beb971c0164f1e8a2f5a27e829"}, | ||||
|     {file = "grpcio-1.62.0-cp39-cp39-manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:29cb592c4ce64a023712875368bcae13938c7f03e99f080407e20ffe0a9aa33b"}, | ||||
|     {file = "grpcio-1.62.0-cp39-cp39-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:1eda79574aec8ec4d00768dcb07daba60ed08ef32583b62b90bbf274b3c279f7"}, | ||||
|     {file = "grpcio-1.62.0-cp39-cp39-musllinux_1_1_i686.whl", hash = "sha256:7eea57444a354ee217fda23f4b479a4cdfea35fb918ca0d8a0e73c271e52c09c"}, | ||||
|     {file = "grpcio-1.62.0-cp39-cp39-musllinux_1_1_x86_64.whl", hash = "sha256:0e97f37a3b7c89f9125b92d22e9c8323f4e76e7993ba7049b9f4ccbe8bae958a"}, | ||||
|     {file = "grpcio-1.62.0-cp39-cp39-win32.whl", hash = "sha256:39cd45bd82a2e510e591ca2ddbe22352e8413378852ae814549c162cf3992a93"}, | ||||
|     {file = "grpcio-1.62.0-cp39-cp39-win_amd64.whl", hash = "sha256:b71c65427bf0ec6a8b48c68c17356cb9fbfc96b1130d20a07cb462f4e4dcdcd5"}, | ||||
|     {file = "grpcio-1.62.0.tar.gz", hash = "sha256:748496af9238ac78dcd98cce65421f1adce28c3979393e3609683fcd7f3880d7"}, | ||||
|     {file = "grpcio-1.62.1-cp310-cp310-linux_armv7l.whl", hash = "sha256:179bee6f5ed7b5f618844f760b6acf7e910988de77a4f75b95bbfaa8106f3c1e"}, | ||||
|     {file = "grpcio-1.62.1-cp310-cp310-macosx_12_0_universal2.whl", hash = "sha256:48611e4fa010e823ba2de8fd3f77c1322dd60cb0d180dc6630a7e157b205f7ea"}, | ||||
|     {file = "grpcio-1.62.1-cp310-cp310-manylinux_2_17_aarch64.whl", hash = "sha256:b2a0e71b0a2158aa4bce48be9f8f9eb45cbd17c78c7443616d00abbe2a509f6d"}, | ||||
|     {file = "grpcio-1.62.1-cp310-cp310-manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:fbe80577c7880911d3ad65e5ecc997416c98f354efeba2f8d0f9112a67ed65a5"}, | ||||
|     {file = "grpcio-1.62.1-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:58f6c693d446964e3292425e1d16e21a97a48ba9172f2d0df9d7b640acb99243"}, | ||||
|     {file = "grpcio-1.62.1-cp310-cp310-musllinux_1_1_i686.whl", hash = "sha256:77c339403db5a20ef4fed02e4d1a9a3d9866bf9c0afc77a42234677313ea22f3"}, | ||||
|     {file = "grpcio-1.62.1-cp310-cp310-musllinux_1_1_x86_64.whl", hash = "sha256:b5a4ea906db7dec694098435d84bf2854fe158eb3cd51e1107e571246d4d1d70"}, | ||||
|     {file = "grpcio-1.62.1-cp310-cp310-win32.whl", hash = "sha256:4187201a53f8561c015bc745b81a1b2d278967b8de35f3399b84b0695e281d5f"}, | ||||
|     {file = "grpcio-1.62.1-cp310-cp310-win_amd64.whl", hash = "sha256:844d1f3fb11bd1ed362d3fdc495d0770cfab75761836193af166fee113421d66"}, | ||||
|     {file = "grpcio-1.62.1-cp311-cp311-linux_armv7l.whl", hash = "sha256:833379943d1728a005e44103f17ecd73d058d37d95783eb8f0b28ddc1f54d7b2"}, | ||||
|     {file = "grpcio-1.62.1-cp311-cp311-macosx_10_10_universal2.whl", hash = "sha256:c7fcc6a32e7b7b58f5a7d27530669337a5d587d4066060bcb9dee7a8c833dfb7"}, | ||||
|     {file = "grpcio-1.62.1-cp311-cp311-manylinux_2_17_aarch64.whl", hash = "sha256:fa7d28eb4d50b7cbe75bb8b45ed0da9a1dc5b219a0af59449676a29c2eed9698"}, | ||||
|     {file = "grpcio-1.62.1-cp311-cp311-manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:48f7135c3de2f298b833be8b4ae20cafe37091634e91f61f5a7eb3d61ec6f660"}, | ||||
|     {file = "grpcio-1.62.1-cp311-cp311-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:71f11fd63365ade276c9d4a7b7df5c136f9030e3457107e1791b3737a9b9ed6a"}, | ||||
|     {file = "grpcio-1.62.1-cp311-cp311-musllinux_1_1_i686.whl", hash = "sha256:4b49fd8fe9f9ac23b78437da94c54aa7e9996fbb220bac024a67469ce5d0825f"}, | ||||
|     {file = "grpcio-1.62.1-cp311-cp311-musllinux_1_1_x86_64.whl", hash = "sha256:482ae2ae78679ba9ed5752099b32e5fe580443b4f798e1b71df412abf43375db"}, | ||||
|     {file = "grpcio-1.62.1-cp311-cp311-win32.whl", hash = "sha256:1faa02530b6c7426404372515fe5ddf66e199c2ee613f88f025c6f3bd816450c"}, | ||||
|     {file = "grpcio-1.62.1-cp311-cp311-win_amd64.whl", hash = "sha256:5bd90b8c395f39bc82a5fb32a0173e220e3f401ff697840f4003e15b96d1befc"}, | ||||
|     {file = "grpcio-1.62.1-cp312-cp312-linux_armv7l.whl", hash = "sha256:b134d5d71b4e0837fff574c00e49176051a1c532d26c052a1e43231f252d813b"}, | ||||
|     {file = "grpcio-1.62.1-cp312-cp312-macosx_10_10_universal2.whl", hash = "sha256:d1f6c96573dc09d50dbcbd91dbf71d5cf97640c9427c32584010fbbd4c0e0037"}, | ||||
|     {file = "grpcio-1.62.1-cp312-cp312-manylinux_2_17_aarch64.whl", hash = "sha256:359f821d4578f80f41909b9ee9b76fb249a21035a061a327f91c953493782c31"}, | ||||
|     {file = "grpcio-1.62.1-cp312-cp312-manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:a485f0c2010c696be269184bdb5ae72781344cb4e60db976c59d84dd6354fac9"}, | ||||
|     {file = "grpcio-1.62.1-cp312-cp312-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:b50b09b4dc01767163d67e1532f948264167cd27f49e9377e3556c3cba1268e1"}, | ||||
|     {file = "grpcio-1.62.1-cp312-cp312-musllinux_1_1_i686.whl", hash = "sha256:3227c667dccbe38f2c4d943238b887bac588d97c104815aecc62d2fd976e014b"}, | ||||
|     {file = "grpcio-1.62.1-cp312-cp312-musllinux_1_1_x86_64.whl", hash = "sha256:3952b581eb121324853ce2b191dae08badb75cd493cb4e0243368aa9e61cfd41"}, | ||||
|     {file = "grpcio-1.62.1-cp312-cp312-win32.whl", hash = "sha256:83a17b303425104d6329c10eb34bba186ffa67161e63fa6cdae7776ff76df73f"}, | ||||
|     {file = "grpcio-1.62.1-cp312-cp312-win_amd64.whl", hash = "sha256:6696ffe440333a19d8d128e88d440f91fb92c75a80ce4b44d55800e656a3ef1d"}, | ||||
|     {file = "grpcio-1.62.1-cp37-cp37m-linux_armv7l.whl", hash = "sha256:e3393b0823f938253370ebef033c9fd23d27f3eae8eb9a8f6264900c7ea3fb5a"}, | ||||
|     {file = "grpcio-1.62.1-cp37-cp37m-macosx_10_10_universal2.whl", hash = "sha256:83e7ccb85a74beaeae2634f10eb858a0ed1a63081172649ff4261f929bacfd22"}, | ||||
|     {file = "grpcio-1.62.1-cp37-cp37m-manylinux_2_17_aarch64.whl", hash = "sha256:882020c87999d54667a284c7ddf065b359bd00251fcd70279ac486776dbf84ec"}, | ||||
|     {file = "grpcio-1.62.1-cp37-cp37m-manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:a10383035e864f386fe096fed5c47d27a2bf7173c56a6e26cffaaa5a361addb1"}, | ||||
|     {file = "grpcio-1.62.1-cp37-cp37m-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:960edebedc6b9ada1ef58e1c71156f28689978188cd8cff3b646b57288a927d9"}, | ||||
|     {file = "grpcio-1.62.1-cp37-cp37m-musllinux_1_1_i686.whl", hash = "sha256:23e2e04b83f347d0aadde0c9b616f4726c3d76db04b438fd3904b289a725267f"}, | ||||
|     {file = "grpcio-1.62.1-cp37-cp37m-musllinux_1_1_x86_64.whl", hash = "sha256:978121758711916d34fe57c1f75b79cdfc73952f1481bb9583399331682d36f7"}, | ||||
|     {file = "grpcio-1.62.1-cp37-cp37m-win_amd64.whl", hash = "sha256:9084086190cc6d628f282e5615f987288b95457292e969b9205e45b442276407"}, | ||||
|     {file = "grpcio-1.62.1-cp38-cp38-linux_armv7l.whl", hash = "sha256:22bccdd7b23c420a27fd28540fb5dcbc97dc6be105f7698cb0e7d7a420d0e362"}, | ||||
|     {file = "grpcio-1.62.1-cp38-cp38-macosx_10_10_universal2.whl", hash = "sha256:8999bf1b57172dbc7c3e4bb3c732658e918f5c333b2942243f10d0d653953ba9"}, | ||||
|     {file = "grpcio-1.62.1-cp38-cp38-manylinux_2_17_aarch64.whl", hash = "sha256:d9e52558b8b8c2f4ac05ac86344a7417ccdd2b460a59616de49eb6933b07a0bd"}, | ||||
|     {file = "grpcio-1.62.1-cp38-cp38-manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:1714e7bc935780bc3de1b3fcbc7674209adf5208ff825799d579ffd6cd0bd505"}, | ||||
|     {file = "grpcio-1.62.1-cp38-cp38-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:c8842ccbd8c0e253c1f189088228f9b433f7a93b7196b9e5b6f87dba393f5d5d"}, | ||||
|     {file = "grpcio-1.62.1-cp38-cp38-musllinux_1_1_i686.whl", hash = "sha256:1f1e7b36bdff50103af95a80923bf1853f6823dd62f2d2a2524b66ed74103e49"}, | ||||
|     {file = "grpcio-1.62.1-cp38-cp38-musllinux_1_1_x86_64.whl", hash = "sha256:bba97b8e8883a8038606480d6b6772289f4c907f6ba780fa1f7b7da7dfd76f06"}, | ||||
|     {file = "grpcio-1.62.1-cp38-cp38-win32.whl", hash = "sha256:a7f615270fe534548112a74e790cd9d4f5509d744dd718cd442bf016626c22e4"}, | ||||
|     {file = "grpcio-1.62.1-cp38-cp38-win_amd64.whl", hash = "sha256:e6c8c8693df718c5ecbc7babb12c69a4e3677fd11de8886f05ab22d4e6b1c43b"}, | ||||
|     {file = "grpcio-1.62.1-cp39-cp39-linux_armv7l.whl", hash = "sha256:73db2dc1b201d20ab7083e7041946910bb991e7e9761a0394bbc3c2632326483"}, | ||||
|     {file = "grpcio-1.62.1-cp39-cp39-macosx_10_10_universal2.whl", hash = "sha256:407b26b7f7bbd4f4751dbc9767a1f0716f9fe72d3d7e96bb3ccfc4aace07c8de"}, | ||||
|     {file = "grpcio-1.62.1-cp39-cp39-manylinux_2_17_aarch64.whl", hash = "sha256:f8de7c8cef9261a2d0a62edf2ccea3d741a523c6b8a6477a340a1f2e417658de"}, | ||||
|     {file = "grpcio-1.62.1-cp39-cp39-manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:9bd5c8a1af40ec305d001c60236308a67e25419003e9bb3ebfab5695a8d0b369"}, | ||||
|     {file = "grpcio-1.62.1-cp39-cp39-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:be0477cb31da67846a33b1a75c611f88bfbcd427fe17701b6317aefceee1b96f"}, | ||||
|     {file = "grpcio-1.62.1-cp39-cp39-musllinux_1_1_i686.whl", hash = "sha256:60dcd824df166ba266ee0cfaf35a31406cd16ef602b49f5d4dfb21f014b0dedd"}, | ||||
|     {file = "grpcio-1.62.1-cp39-cp39-musllinux_1_1_x86_64.whl", hash = "sha256:973c49086cabab773525f6077f95e5a993bfc03ba8fc32e32f2c279497780585"}, | ||||
|     {file = "grpcio-1.62.1-cp39-cp39-win32.whl", hash = "sha256:12859468e8918d3bd243d213cd6fd6ab07208195dc140763c00dfe901ce1e1b4"}, | ||||
|     {file = "grpcio-1.62.1-cp39-cp39-win_amd64.whl", hash = "sha256:b7209117bbeebdfa5d898205cc55153a51285757902dd73c47de498ad4d11332"}, | ||||
|     {file = "grpcio-1.62.1.tar.gz", hash = "sha256:6c455e008fa86d9e9a9d85bb76da4277c0d7d9668a3bfa70dbe86e9f3c759947"}, | ||||
| ] | ||||
| 
 | ||||
| [package.extras] | ||||
| protobuf = ["grpcio-tools (>=1.62.0)"] | ||||
| protobuf = ["grpcio-tools (>=1.62.1)"] | ||||
| 
 | ||||
| [[package]] | ||||
| name = "grpcio-tools" | ||||
| version = "1.62.0" | ||||
| version = "1.62.1" | ||||
| description = "Protobuf code generator for gRPC" | ||||
| optional = false | ||||
| python-versions = ">=3.7" | ||||
| files = [ | ||||
|     {file = "grpcio-tools-1.62.0.tar.gz", hash = "sha256:7fca6ecfbbf0549058bb29dcc6e435d885b878d07701e77ac58e1e1f591736dc"}, | ||||
|     {file = "grpcio_tools-1.62.0-cp310-cp310-linux_armv7l.whl", hash = "sha256:465c51ebaa184ee3bb619cd5bfaf562bbdde166f2822a6935461e6a741f5ac19"}, | ||||
|     {file = "grpcio_tools-1.62.0-cp310-cp310-macosx_12_0_universal2.whl", hash = "sha256:0d9c9a4832f52c4597d6dc12d9ab3109c3bd0ee1686b8bf6d64f9eab4145e3cb"}, | ||||
|     {file = "grpcio_tools-1.62.0-cp310-cp310-manylinux_2_17_aarch64.whl", hash = "sha256:5a482d9625209023481e631c29a6df1392bfc49f9accfa880dabbacff642559a"}, | ||||
|     {file = "grpcio_tools-1.62.0-cp310-cp310-manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:74196beed18383d53ff3e2412a6c1eefa3ff109e987be240368496bc3dcabc8b"}, | ||||
|     {file = "grpcio_tools-1.62.0-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:75aca28cbeb605c59b5689a7e000fbc2bd659d2f322c58461f3912f00069f6da"}, | ||||
|     {file = "grpcio_tools-1.62.0-cp310-cp310-musllinux_1_1_i686.whl", hash = "sha256:523adf731fa4c5af0bf7ee2edb65e8c7ef4d9df9951461d6a18fe096688efd2d"}, | ||||
|     {file = "grpcio_tools-1.62.0-cp310-cp310-musllinux_1_1_x86_64.whl", hash = "sha256:791aa220f8f1936e65bc079e9eb954fa0202a1f16e28b83956e59d17dface127"}, | ||||
|     {file = "grpcio_tools-1.62.0-cp310-cp310-win32.whl", hash = "sha256:5dacc691b18d2c294ea971720ff980a1e2d68a3f7ddcd2f0670b3204e81c4b18"}, | ||||
|     {file = "grpcio_tools-1.62.0-cp310-cp310-win_amd64.whl", hash = "sha256:6999a4e705b03aacad46e625feb7610e47ec88dbd51220c2282b6334f90721fc"}, | ||||
|     {file = "grpcio_tools-1.62.0-cp311-cp311-linux_armv7l.whl", hash = "sha256:19b74e141937c885c9e56b6a7dfa190ca7d583bd48bce9171dd65bbf108b9271"}, | ||||
|     {file = "grpcio_tools-1.62.0-cp311-cp311-macosx_10_10_universal2.whl", hash = "sha256:17c16e9a89c0b9f4ff2b143f232c5256383453ce7b55fe981598f9517adc8252"}, | ||||
|     {file = "grpcio_tools-1.62.0-cp311-cp311-manylinux_2_17_aarch64.whl", hash = "sha256:3730b1cd998a0cffc817602cc55e51f268fa97b3e38fa4bee578e3741474547a"}, | ||||
|     {file = "grpcio_tools-1.62.0-cp311-cp311-manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:14201950513636f515dd455a06890e3a21d115b943cf6a8f5af67ad1413cfa1f"}, | ||||
|     {file = "grpcio_tools-1.62.0-cp311-cp311-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:f74e0053360e0eadd75193c0c379b6d7f51d074ebbff856bd41780e1a028b38d"}, | ||||
|     {file = "grpcio_tools-1.62.0-cp311-cp311-musllinux_1_1_i686.whl", hash = "sha256:d5959e3df126931d28cd94dd5f0a708b7dd96019de80ab715fb922fd0c8a838d"}, | ||||
|     {file = "grpcio_tools-1.62.0-cp311-cp311-musllinux_1_1_x86_64.whl", hash = "sha256:1927934dfba4658a97c2dab267e53ed239264d40fdd5b295fc317693543db85b"}, | ||||
|     {file = "grpcio_tools-1.62.0-cp311-cp311-win32.whl", hash = "sha256:2f5bd22203e64e1732e149bfdd3083716d038abca294e4e2852159b3d893f9ec"}, | ||||
|     {file = "grpcio_tools-1.62.0-cp311-cp311-win_amd64.whl", hash = "sha256:cd1f4caeca614b04db803566473f7db0971e7a88268f95e4a529b0ace699b949"}, | ||||
|     {file = "grpcio_tools-1.62.0-cp312-cp312-linux_armv7l.whl", hash = "sha256:f0884eaf6a2bbd7b03fea456e808909ee48dd4f7f455519d67defda791116368"}, | ||||
|     {file = "grpcio_tools-1.62.0-cp312-cp312-macosx_10_10_universal2.whl", hash = "sha256:6b900ae319b6f9ac1be0ca572dfb41c23a7ff6fcbf36e3be6d3054e1e4c60de6"}, | ||||
|     {file = "grpcio_tools-1.62.0-cp312-cp312-manylinux_2_17_aarch64.whl", hash = "sha256:3bbe79b134dfb7c98cf60e4962e31039bef824834cc7034bdf1886a2ed1097f9"}, | ||||
|     {file = "grpcio_tools-1.62.0-cp312-cp312-manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:77196c7ac8741d4a2aebb023bcc2964ac65ca44180fd791640889ab2afed3e47"}, | ||||
|     {file = "grpcio_tools-1.62.0-cp312-cp312-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:b65288ebe12e38dd3650fea65d82fcce0d35df1ae4a770b525c10119ee71962f"}, | ||||
|     {file = "grpcio_tools-1.62.0-cp312-cp312-musllinux_1_1_i686.whl", hash = "sha256:52b216c458458f6c292e12428916e80974c5113abc505a61e7b0b9f8932a785d"}, | ||||
|     {file = "grpcio_tools-1.62.0-cp312-cp312-musllinux_1_1_x86_64.whl", hash = "sha256:88aa62303278aec45bbb26bf679269c7890346c37140ae30e39da1070c341e11"}, | ||||
|     {file = "grpcio_tools-1.62.0-cp312-cp312-win32.whl", hash = "sha256:bb6802d63e42734d2baf02e1343377fe18590ed6a1f5ffbdebbbe0f8331f176b"}, | ||||
|     {file = "grpcio_tools-1.62.0-cp312-cp312-win_amd64.whl", hash = "sha256:d5652d3a52a2e8e1d9bdf28fbd15e21b166e31b968cd7c8c604bf31611c0bb5b"}, | ||||
|     {file = "grpcio_tools-1.62.0-cp37-cp37m-linux_armv7l.whl", hash = "sha256:84e27206bd884be83a7fdcef8be3c90eb1591341c0ba9b0d25ec9db1043ba2f2"}, | ||||
|     {file = "grpcio_tools-1.62.0-cp37-cp37m-macosx_10_10_universal2.whl", hash = "sha256:5eb63d9207b02a0fa30216907e1e7705cc2670f933e77236c6e0eb966ad3b4bf"}, | ||||
|     {file = "grpcio_tools-1.62.0-cp37-cp37m-manylinux_2_17_aarch64.whl", hash = "sha256:95e49839d49e79187c43cd63af5c206dc5743a01d7d3d2f039772fa743cbb30c"}, | ||||
|     {file = "grpcio_tools-1.62.0-cp37-cp37m-manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:9ae5cd2f89e33a529790bf8aa59a459484edb05e4f58d4cf78836b9dfa1fab43"}, | ||||
|     {file = "grpcio_tools-1.62.0-cp37-cp37m-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:2e1fd7301d762bf5984b7e7fb62fce82cff864d75f0a57e15cfd07ae1bd79133"}, | ||||
|     {file = "grpcio_tools-1.62.0-cp37-cp37m-musllinux_1_1_i686.whl", hash = "sha256:e38d5800151e6804d500e329f7ddfb615c50eee0c1607593e3147a4b21037e40"}, | ||||
|     {file = "grpcio_tools-1.62.0-cp37-cp37m-musllinux_1_1_x86_64.whl", hash = "sha256:563a75924109e75809b2919e68d7e6ae7872e63d20258aae7899b14f6ff9e18b"}, | ||||
|     {file = "grpcio_tools-1.62.0-cp37-cp37m-win_amd64.whl", hash = "sha256:5f8934715577c9cc0c792b8a77f7d0dd2bb60e951161b10c5f46b60856673240"}, | ||||
|     {file = "grpcio_tools-1.62.0-cp38-cp38-linux_armv7l.whl", hash = "sha256:ed6cf7ff4a10c46f85340f9c68982f9efb29f51ee4b66828310fcdf3c2d7ffd1"}, | ||||
|     {file = "grpcio_tools-1.62.0-cp38-cp38-macosx_10_10_universal2.whl", hash = "sha256:1faa5006fe9e7b9e65c47bc23f7cd333fdcdd4ba35d44080303848266db5ab05"}, | ||||
|     {file = "grpcio_tools-1.62.0-cp38-cp38-manylinux_2_17_aarch64.whl", hash = "sha256:3b526dc5566161a3a17599753838b9cfbdd4cb15b6ad419aae8a5d12053fa8ae"}, | ||||
|     {file = "grpcio_tools-1.62.0-cp38-cp38-manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:a09db3688efd3499ce3c0b02c0bac0656abdab4cb99716f81ad879c08b92c56e"}, | ||||
|     {file = "grpcio_tools-1.62.0-cp38-cp38-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:006ea0cc16e8bf8f307326e0556e1384f24abb402cc4e6a720aa1dfe8f268647"}, | ||||
|     {file = "grpcio_tools-1.62.0-cp38-cp38-musllinux_1_1_i686.whl", hash = "sha256:b46ba0b6552b4375ede65e0c89491af532635347f78d52a72f8a027529e713ed"}, | ||||
|     {file = "grpcio_tools-1.62.0-cp38-cp38-musllinux_1_1_x86_64.whl", hash = "sha256:ec6f561c86fe13cff3be16f297cc05e1aa1274294524743a4cf91d971866fbb0"}, | ||||
|     {file = "grpcio_tools-1.62.0-cp38-cp38-win32.whl", hash = "sha256:c85391e06620d6e16a56341caae5007d0c6219beba065e1e288f2523fba6a335"}, | ||||
|     {file = "grpcio_tools-1.62.0-cp38-cp38-win_amd64.whl", hash = "sha256:679cf2507090e010da73e5001665c76de2a5927b2e2110e459222b1c81cb10c2"}, | ||||
|     {file = "grpcio_tools-1.62.0-cp39-cp39-linux_armv7l.whl", hash = "sha256:0e87f105f1d152934759f8975ed002d5ce057b3cdf1cc6cb63fe6008671a27b9"}, | ||||
|     {file = "grpcio_tools-1.62.0-cp39-cp39-macosx_10_10_universal2.whl", hash = "sha256:bf9f281f528e0220558d57e09b4518dec148dcb250d78bd9cbb27e09edabb3f9"}, | ||||
|     {file = "grpcio_tools-1.62.0-cp39-cp39-manylinux_2_17_aarch64.whl", hash = "sha256:711314cb4c6c8b3d51bafaee380ffa5012bd0567ed68f1b0b1fc07492b27acab"}, | ||||
|     {file = "grpcio_tools-1.62.0-cp39-cp39-manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:54bb570bd963905de3bda596b35e06026552705edebbb2cb737b57aa5252b9e5"}, | ||||
|     {file = "grpcio_tools-1.62.0-cp39-cp39-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:dce5f04676cf94e6e2d13d7f91ac2de79097d86675bc4d404a3c24dcc0332c88"}, | ||||
|     {file = "grpcio_tools-1.62.0-cp39-cp39-musllinux_1_1_i686.whl", hash = "sha256:98ddf871c614cc0ed331c7159ebbbf5040be562279677d3bb97c2e6083539f72"}, | ||||
|     {file = "grpcio_tools-1.62.0-cp39-cp39-musllinux_1_1_x86_64.whl", hash = "sha256:f3aaf3b20c0f7063856b2432335af8f76cf580f898e04085548cde28332d6833"}, | ||||
|     {file = "grpcio_tools-1.62.0-cp39-cp39-win32.whl", hash = "sha256:3dee3be61d9032f777a9b4e2696ea3d0748a582cb99c672b5d41ca66821e8c87"}, | ||||
|     {file = "grpcio_tools-1.62.0-cp39-cp39-win_amd64.whl", hash = "sha256:f54b5181784464bd3573ae7dbcf053da18a4b7a75fe19960791f383be3d035ca"}, | ||||
|     {file = "grpcio-tools-1.62.1.tar.gz", hash = "sha256:a4991e5ee8a97ab791296d3bf7e8700b1445635cc1828cc98df945ca1802d7f2"}, | ||||
|     {file = "grpcio_tools-1.62.1-cp310-cp310-linux_armv7l.whl", hash = "sha256:f2b404bcae7e2ef9b0b9803b2a95119eb7507e6dc80ea4a64a78be052c30cebc"}, | ||||
|     {file = "grpcio_tools-1.62.1-cp310-cp310-macosx_12_0_universal2.whl", hash = "sha256:fdd987a580b4474769adfd40144486f54bcc73838d5ec5d3647a17883ea78e76"}, | ||||
|     {file = "grpcio_tools-1.62.1-cp310-cp310-manylinux_2_17_aarch64.whl", hash = "sha256:07af1a6442e2313cff22af93c2c4dd37ae32b5239b38e0d99e2cbf93de65429f"}, | ||||
|     {file = "grpcio_tools-1.62.1-cp310-cp310-manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:41384c9ee18e61ef20cad2774ef71bd8854b63efce263b5177aa06fccb84df1f"}, | ||||
|     {file = "grpcio_tools-1.62.1-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:5c38006f7702d2ff52122e4c77a47348709374050c76216e84b30a9f06e45afa"}, | ||||
|     {file = "grpcio_tools-1.62.1-cp310-cp310-musllinux_1_1_i686.whl", hash = "sha256:08fecc3c5b4e6dd3278f2b9d12837e423c7dcff551ca1e587018b4a0fc5f8019"}, | ||||
|     {file = "grpcio_tools-1.62.1-cp310-cp310-musllinux_1_1_x86_64.whl", hash = "sha256:a01e8dcd0f041f6fa6d815c54a2017d032950e310c41d514a8bc041e872c4d12"}, | ||||
|     {file = "grpcio_tools-1.62.1-cp310-cp310-win32.whl", hash = "sha256:dd933b8e0b3c13fe3543d58f849a6a5e0d7987688cb6801834278378c724f695"}, | ||||
|     {file = "grpcio_tools-1.62.1-cp310-cp310-win_amd64.whl", hash = "sha256:2b04844a9382f1bde4b4174e476e654ab3976168d2469cb4b29e352f4f35a5aa"}, | ||||
|     {file = "grpcio_tools-1.62.1-cp311-cp311-linux_armv7l.whl", hash = "sha256:024380536ba71a96cdf736f0954f6ad03f5da609c09edbcc2ca02fdd639e0eed"}, | ||||
|     {file = "grpcio_tools-1.62.1-cp311-cp311-macosx_10_10_universal2.whl", hash = "sha256:21f14b99e0cd38ad56754cc0b62b2bf3cf75f9f7fc40647da54669e0da0726fe"}, | ||||
|     {file = "grpcio_tools-1.62.1-cp311-cp311-manylinux_2_17_aarch64.whl", hash = "sha256:975ac5fb482c23f3608c16e06a43c8bab4d79c2e2564cdbc25cf753c6e998775"}, | ||||
|     {file = "grpcio_tools-1.62.1-cp311-cp311-manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:50739aaab0c8076ad5957204e71f2e0c9876e11fd8338f7f09de12c2d75163c5"}, | ||||
|     {file = "grpcio_tools-1.62.1-cp311-cp311-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:598c54318f0326cf5020aa43fc95a15e933aba4a71943d3bff2677d2d21ddfa1"}, | ||||
|     {file = "grpcio_tools-1.62.1-cp311-cp311-musllinux_1_1_i686.whl", hash = "sha256:f309bdb33a61f8e049480d41498ee2e525cfb5e959958b326abfdf552bf9b9cb"}, | ||||
|     {file = "grpcio_tools-1.62.1-cp311-cp311-musllinux_1_1_x86_64.whl", hash = "sha256:f358effd3c11d66c150e0227f983d54a5cd30e14038566dadcf25f9f6844e6e8"}, | ||||
|     {file = "grpcio_tools-1.62.1-cp311-cp311-win32.whl", hash = "sha256:b76aead9b73f1650a091870fe4e9ed15ac4d8ed136f962042367255199c23594"}, | ||||
|     {file = "grpcio_tools-1.62.1-cp311-cp311-win_amd64.whl", hash = "sha256:d66a5d47eaa427039752fa0a83a425ff2a487b6a0ac30556fd3be2f3a27a0130"}, | ||||
|     {file = "grpcio_tools-1.62.1-cp312-cp312-linux_armv7l.whl", hash = "sha256:575535d039b97d63e6a9abee626d6c7cd47bd8cb73dd00a5c84a98254a2164a4"}, | ||||
|     {file = "grpcio_tools-1.62.1-cp312-cp312-macosx_10_10_universal2.whl", hash = "sha256:22644c90e43d1a888477899af917979e17364fdd6e9bbb92679cd6a54c4d36c3"}, | ||||
|     {file = "grpcio_tools-1.62.1-cp312-cp312-manylinux_2_17_aarch64.whl", hash = "sha256:156d3e1b227c16e903003a56881dbe60e40f2b4bd66f0bc3b27c53e466e6384d"}, | ||||
|     {file = "grpcio_tools-1.62.1-cp312-cp312-manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:5ad7c5691625a85327e5b683443baf73ae790fd5afc938252041ed5cd665e377"}, | ||||
|     {file = "grpcio_tools-1.62.1-cp312-cp312-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:0e140bbc08eea8abf51c0274f45fb1e8350220e64758998d7f3c7f985a0b2496"}, | ||||
|     {file = "grpcio_tools-1.62.1-cp312-cp312-musllinux_1_1_i686.whl", hash = "sha256:7444fcab861911525470d398e5638b70d5cbea3b4674a3de92b5c58c5c515d4d"}, | ||||
|     {file = "grpcio_tools-1.62.1-cp312-cp312-musllinux_1_1_x86_64.whl", hash = "sha256:e643cd14a5d1e59865cba68a5a6f0175d987f36c5f4cb0db80dee9ed60b4c174"}, | ||||
|     {file = "grpcio_tools-1.62.1-cp312-cp312-win32.whl", hash = "sha256:1344a773d2caa9bb7fbea7e879b84f33740c808c34a5bd2a2768e526117a6b44"}, | ||||
|     {file = "grpcio_tools-1.62.1-cp312-cp312-win_amd64.whl", hash = "sha256:2eea1db3748b2f37b4dce84d8e0c15d9bc811094807cabafe7b0ea47f424dfd5"}, | ||||
|     {file = "grpcio_tools-1.62.1-cp37-cp37m-linux_armv7l.whl", hash = "sha256:45d2e6cf04d27286b6f73e6e20ba3f0a1f6d8f5535e5dcb1356200419bb457f4"}, | ||||
|     {file = "grpcio_tools-1.62.1-cp37-cp37m-macosx_10_10_universal2.whl", hash = "sha256:46ae58e6926773e7315e9005f0f17aacedbc0895a8752bec087d24efa2f1fb21"}, | ||||
|     {file = "grpcio_tools-1.62.1-cp37-cp37m-manylinux_2_17_aarch64.whl", hash = "sha256:4c28086df31478023a36f45e50767872ab3aed2419afff09814cb61c88b77db4"}, | ||||
|     {file = "grpcio_tools-1.62.1-cp37-cp37m-manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:a4fba5b339f4797548591036c9481e6895bf920fab7d3dc664d2697f8fb7c0bf"}, | ||||
|     {file = "grpcio_tools-1.62.1-cp37-cp37m-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:23eb3d47f78f509fcd201749b1f1e44b76f447913f7fbb3b8bae20f109086295"}, | ||||
|     {file = "grpcio_tools-1.62.1-cp37-cp37m-musllinux_1_1_i686.whl", hash = "sha256:fd5d47707bd6bc2b707ece765c362d2a1d2e8f6cd92b04c99fab49a929f3610c"}, | ||||
|     {file = "grpcio_tools-1.62.1-cp37-cp37m-musllinux_1_1_x86_64.whl", hash = "sha256:d1924a6a943df7c73b9ef0048302327c75962b567451479710da729ead241228"}, | ||||
|     {file = "grpcio_tools-1.62.1-cp37-cp37m-win_amd64.whl", hash = "sha256:fe71ca30aabe42591e84ecb9694c0297dc699cc20c5b24d2cb267fb0fc01f947"}, | ||||
|     {file = "grpcio_tools-1.62.1-cp38-cp38-linux_armv7l.whl", hash = "sha256:1819fd055c1ae672d1d725ec75eefd1f700c18acba0ed9332202be31d69c401d"}, | ||||
|     {file = "grpcio_tools-1.62.1-cp38-cp38-macosx_10_10_universal2.whl", hash = "sha256:5dbe1f7481dd14b6d477b4bace96d275090bc7636b9883975a08b802c94e7b78"}, | ||||
|     {file = "grpcio_tools-1.62.1-cp38-cp38-manylinux_2_17_aarch64.whl", hash = "sha256:771c051c5ece27ad03e4f2e33624a925f0ad636c01757ab7dbb04a37964af4ba"}, | ||||
|     {file = "grpcio_tools-1.62.1-cp38-cp38-manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:98209c438b38b6f1276dbc27b1c04e346a75bfaafe72a25a548f2dc5ce71d226"}, | ||||
|     {file = "grpcio_tools-1.62.1-cp38-cp38-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:2152308e5321cb90fb45aaa84d03d6dedb19735a8779aaf36c624f97b831842d"}, | ||||
|     {file = "grpcio_tools-1.62.1-cp38-cp38-musllinux_1_1_i686.whl", hash = "sha256:ed1f27dc2b2262c8b8d9036276619c1bb18791311c16ccbf1f31b660f2aad7cf"}, | ||||
|     {file = "grpcio_tools-1.62.1-cp38-cp38-musllinux_1_1_x86_64.whl", hash = "sha256:2744947b6c5e907af21133431809ccca535a037356864e32c122efed8cb9de1f"}, | ||||
|     {file = "grpcio_tools-1.62.1-cp38-cp38-win32.whl", hash = "sha256:13b20e269d14ad629ff9a2c9a2450f3dbb119d5948de63b27ffe624fa7aea85a"}, | ||||
|     {file = "grpcio_tools-1.62.1-cp38-cp38-win_amd64.whl", hash = "sha256:999823758e9eacd0095863d06cd6d388be769f80c9abb65cdb11c4f2cfce3fea"}, | ||||
|     {file = "grpcio_tools-1.62.1-cp39-cp39-linux_armv7l.whl", hash = "sha256:941f8a5c31986053e75fa466bcfa743c2bf1b513b7978cf1f4ab4e96a8219d27"}, | ||||
|     {file = "grpcio_tools-1.62.1-cp39-cp39-macosx_10_10_universal2.whl", hash = "sha256:b9c02c88c77ef6057c6cbeea8922d7c2424aabf46bfc40ddf42a32765ba91061"}, | ||||
|     {file = "grpcio_tools-1.62.1-cp39-cp39-manylinux_2_17_aarch64.whl", hash = "sha256:6abd4eb3ccb444383a40156139acc3aaa73745d395139cb6bc8e2a3429e1e627"}, | ||||
|     {file = "grpcio_tools-1.62.1-cp39-cp39-manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:449503213d142f8470b331a1c2f346f8457f16c7fe20f531bc2500e271f7c14c"}, | ||||
|     {file = "grpcio_tools-1.62.1-cp39-cp39-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:9a11bcf609d00cfc9baed77ab308223cabc1f0b22a05774a26dd4c94c0c80f1f"}, | ||||
|     {file = "grpcio_tools-1.62.1-cp39-cp39-musllinux_1_1_i686.whl", hash = "sha256:5d7bdea33354b55acf40bb4dd3ba7324d6f1ef6b4a1a4da0807591f8c7e87b9a"}, | ||||
|     {file = "grpcio_tools-1.62.1-cp39-cp39-musllinux_1_1_x86_64.whl", hash = "sha256:d03b645852d605f43003020e78fe6d573cae6ee6b944193e36b8b317e7549a20"}, | ||||
|     {file = "grpcio_tools-1.62.1-cp39-cp39-win32.whl", hash = "sha256:52b185dfc3bf32e70929310367dbc66185afba60492a6a75a9b1141d407e160c"}, | ||||
|     {file = "grpcio_tools-1.62.1-cp39-cp39-win_amd64.whl", hash = "sha256:63a273b70896d3640b7a883eb4a080c3c263d91662d870a2e9c84b7bbd978e7b"}, | ||||
| ] | ||||
| 
 | ||||
| [package.dependencies] | ||||
| grpcio = ">=1.62.0" | ||||
| grpcio = ">=1.62.1" | ||||
| protobuf = ">=4.21.6,<5.0dev" | ||||
| setuptools = "*" | ||||
| 
 | ||||
| @ -553,13 +553,13 @@ files = [ | ||||
| 
 | ||||
| [[package]] | ||||
| name = "packaging" | ||||
| version = "23.2" | ||||
| version = "24.0" | ||||
| description = "Core utilities for Python packages" | ||||
| optional = false | ||||
| python-versions = ">=3.7" | ||||
| files = [ | ||||
|     {file = "packaging-23.2-py3-none-any.whl", hash = "sha256:8c491190033a9af7e1d931d0b5dacc2ef47509b34dd0de67ed209b5203fc88c7"}, | ||||
|     {file = "packaging-23.2.tar.gz", hash = "sha256:048fb0e9405036518eaaf48a55953c750c11e1a1b68e0dd1a9d62ed0c092cfc5"}, | ||||
|     {file = "packaging-24.0-py3-none-any.whl", hash = "sha256:2ddfb553fdf02fb784c234c7ba6ccc288296ceabec964ad2eae3777778130bc5"}, | ||||
|     {file = "packaging-24.0.tar.gz", hash = "sha256:eb82c5e3e56209074766e6885bb04b8c38a0c015d0a30036ebe7ece34c9989e9"}, | ||||
| ] | ||||
| 
 | ||||
| [[package]] | ||||
| @ -633,18 +633,18 @@ xml = ["lxml (>=4.9.2)"] | ||||
| 
 | ||||
| [[package]] | ||||
| name = "playwright" | ||||
| version = "1.41.2" | ||||
| version = "1.42.0" | ||||
| description = "A high-level API to automate web browsers" | ||||
| optional = false | ||||
| python-versions = ">=3.8" | ||||
| files = [ | ||||
|     {file = "playwright-1.41.2-py3-none-macosx_10_13_x86_64.whl", hash = "sha256:cf68335a5dfa4038fa797a4ba0105faee0094ebbb372547d7a27feec5b23c672"}, | ||||
|     {file = "playwright-1.41.2-py3-none-macosx_11_0_arm64.whl", hash = "sha256:431e3a05f8c99147995e2b3e8475d07818745294fd99f1510b61756e73bdcf68"}, | ||||
|     {file = "playwright-1.41.2-py3-none-macosx_11_0_universal2.whl", hash = "sha256:0608717cbf291a625ba6f751061af0fc0cc9bdace217e69d87b1eb1383b03406"}, | ||||
|     {file = "playwright-1.41.2-py3-none-manylinux1_x86_64.whl", hash = "sha256:4bf214d812092cf5b9b9648ba84611aa35e28685519911342a7da3a3031f9ed6"}, | ||||
|     {file = "playwright-1.41.2-py3-none-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:eaa17ab44622c447de26ed8f7d99912719568d8dbc3a9db0e07f0ae1487709d9"}, | ||||
|     {file = "playwright-1.41.2-py3-none-win32.whl", hash = "sha256:edb210a015e70bb0d328bf1c9b65fa3a08361f33e4d7c4ddd1ad2adb6d9b4479"}, | ||||
|     {file = "playwright-1.41.2-py3-none-win_amd64.whl", hash = "sha256:71ead0f33e00f5a8533c037c647938b99f219436a1b27d4ba4de4e6bf0567278"}, | ||||
|     {file = "playwright-1.42.0-py3-none-macosx_10_13_x86_64.whl", hash = "sha256:e2b293f077efeaa45253fde31cea4bc6b0ae8be6b5e65e8ce8b4aa3b9f0d55b6"}, | ||||
|     {file = "playwright-1.42.0-py3-none-macosx_11_0_arm64.whl", hash = "sha256:283887f0bdd0039c3d720e32fbc73a045c24fa800599a6ad60fb199c29580534"}, | ||||
|     {file = "playwright-1.42.0-py3-none-macosx_11_0_universal2.whl", hash = "sha256:4e1fc1c049a0af64626ddd50814d14a01f316bcbb4d1aa83c3416fe420add558"}, | ||||
|     {file = "playwright-1.42.0-py3-none-manylinux1_x86_64.whl", hash = "sha256:313f2551a772f57c9ccca017c4dd4661f2277166f9e1d84bbf5a2e316f0f892c"}, | ||||
|     {file = "playwright-1.42.0-py3-none-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:b2a46a24641e5d468046cde567c98fdb8d85e32df901630b14dfb288cbd1ed4f"}, | ||||
|     {file = "playwright-1.42.0-py3-none-win32.whl", hash = "sha256:dbf473496808d4c2c816902c1dee2aabc029648e56ce8514b643f5a1a6fc8e22"}, | ||||
|     {file = "playwright-1.42.0-py3-none-win_amd64.whl", hash = "sha256:e092c6cfbf797bff03fbdfc53c3e6a9e29fbcf6b82f9e43113d37494aee0561b"}, | ||||
| ] | ||||
| 
 | ||||
| [package.dependencies] | ||||
| @ -800,13 +800,13 @@ tests = ["hypothesis (>=3.27.0)", "pytest (>=3.2.1,!=3.3.0)"] | ||||
| 
 | ||||
| [[package]] | ||||
| name = "pytest" | ||||
| version = "8.0.2" | ||||
| version = "8.1.1" | ||||
| description = "pytest: simple powerful testing with Python" | ||||
| optional = false | ||||
| python-versions = ">=3.8" | ||||
| files = [ | ||||
|     {file = "pytest-8.0.2-py3-none-any.whl", hash = "sha256:edfaaef32ce5172d5466b5127b42e0d6d35ebbe4453f0e3505d96afd93f6b096"}, | ||||
|     {file = "pytest-8.0.2.tar.gz", hash = "sha256:d4051d623a2e0b7e51960ba963193b09ce6daeb9759a451844a21e4ddedfc1bd"}, | ||||
|     {file = "pytest-8.1.1-py3-none-any.whl", hash = "sha256:2a8386cfc11fa9d2c50ee7b2a57e7d898ef90470a7a34c4b949ff59662bb78b7"}, | ||||
|     {file = "pytest-8.1.1.tar.gz", hash = "sha256:ac978141a75948948817d360297b7aae0fcb9d6ff6bc9ec6d514b85d5a65c044"}, | ||||
| ] | ||||
| 
 | ||||
| [package.dependencies] | ||||
| @ -814,11 +814,11 @@ colorama = {version = "*", markers = "sys_platform == \"win32\""} | ||||
| exceptiongroup = {version = ">=1.0.0rc8", markers = "python_version < \"3.11\""} | ||||
| iniconfig = "*" | ||||
| packaging = "*" | ||||
| pluggy = ">=1.3.0,<2.0" | ||||
| tomli = {version = ">=1.0.0", markers = "python_version < \"3.11\""} | ||||
| pluggy = ">=1.4,<2.0" | ||||
| tomli = {version = ">=1", markers = "python_version < \"3.11\""} | ||||
| 
 | ||||
| [package.extras] | ||||
| testing = ["argcomplete", "attrs (>=19.2.0)", "hypothesis (>=3.56)", "mock", "nose", "pygments (>=2.7.2)", "requests", "setuptools", "xmlschema"] | ||||
| testing = ["argcomplete", "attrs (>=19.2)", "hypothesis (>=3.56)", "mock", "pygments (>=2.7.2)", "requests", "setuptools", "xmlschema"] | ||||
| 
 | ||||
| [[package]] | ||||
| name = "pytest-base-url" | ||||
| @ -1347,4 +1347,4 @@ files = [ | ||||
| [metadata] | ||||
| lock-version = "2.0" | ||||
| python-versions = ">=3.9,<3.11" | ||||
| content-hash = "39ce8400de7bf060857447281ef27bd78c9b1d9639da063b051e3ae6e7887a67" | ||||
| content-hash = "b855a4321555c6df372e5ba953a7a1996f920a19e6569d09d015cf35e60e5054" | ||||
|  | ||||
| @ -9,7 +9,7 @@ packages = [{include = "trading market-sim e2e"}] | ||||
| [tool.poetry.dependencies] | ||||
| python = ">=3.9,<3.11" | ||||
| psutil = "^5.9.5" | ||||
| vega-sim = {git = "https://github.com/vegaprotocol/vega-market-sim.git/"} | ||||
| vega-sim = {git = "https://github.com/vegaprotocol/vega-market-sim.git/", branch = "console-e2e-main"} | ||||
| pytest-playwright = "^0.4.2" | ||||
| docker = "^6.1.3" | ||||
| pytest-xdist = "^3.3.1" | ||||
|  | ||||
| @ -63,9 +63,9 @@ def test_renders_markets_correctly(proposed_market, page: Page): | ||||
| 
 | ||||
|     # 6001-MARK-052 | ||||
|     # 6001-MARK-053 | ||||
|     expect(row.locator('[col-id="state"]')).to_have_text("Open") | ||||
|     expect(row.locator('[col-id="state"]')).to_have_text("Proposed") | ||||
|     expect( | ||||
|         row.locator('[col-id="terms.change.successorConfiguration.parentMarketId"]') | ||||
|         row.locator('[col-id="parentMarketID"]') | ||||
|     ).to_have_text("-") | ||||
| 
 | ||||
|     # 6001-MARK-056 | ||||
|  | ||||
| @ -17,6 +17,32 @@ type TradingModeTooltipProps = { | ||||
|   skipGrid?: boolean; | ||||
| }; | ||||
| 
 | ||||
| const useEnactmentDatetime = (marketId?: string, skip?: boolean) => { | ||||
|   const variables = useMemo(() => ({ marketId: marketId || '' }), [marketId]); | ||||
|   const { data: proposalData } = useProposalOfMarketQuery({ | ||||
|     variables, | ||||
|     skip, | ||||
|   }); | ||||
| 
 | ||||
|   let v: string = ''; | ||||
|   if (proposalData?.proposal) { | ||||
|     if (proposalData?.proposal?.__typename === 'Proposal') { | ||||
|       v = proposalData.proposal.terms.enactmentDatetime; | ||||
|     } | ||||
|     if ( | ||||
|       proposalData?.proposal?.__typename === 'BatchProposal' && | ||||
|       proposalData.proposal.subProposals | ||||
|     ) { | ||||
|       const sub = proposalData.proposal.subProposals.find( | ||||
|         (p) => p?.id === variables.marketId | ||||
|       ); | ||||
|       v = sub?.terms?.enactmentDatetime; | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
|   return parseISO(v); | ||||
| }; | ||||
| 
 | ||||
| export const TradingModeTooltip = ({ | ||||
|   marketId, | ||||
|   onSelect, | ||||
| @ -27,31 +53,16 @@ export const TradingModeTooltip = ({ | ||||
|   const { data: market } = useMarket(marketId); | ||||
|   const { data: marketData } = useStaticMarketData(marketId, skip); | ||||
|   const { marketTradingMode, trigger } = marketData || {}; | ||||
|   const variables = useMemo(() => ({ marketId: marketId || '' }), [marketId]); | ||||
|   const { data: proposalData } = useProposalOfMarketQuery({ | ||||
|     variables, | ||||
|     skip: | ||||
| 
 | ||||
|   const skipEnactmentDate = | ||||
|     !marketTradingMode || | ||||
|       Schema.MarketTradingMode.TRADING_MODE_OPENING_AUCTION !== | ||||
|         marketTradingMode, | ||||
|   }); | ||||
|     Schema.MarketTradingMode.TRADING_MODE_OPENING_AUCTION !== marketTradingMode; | ||||
|   const enactmentDate = useEnactmentDatetime(marketId, skipEnactmentDate); | ||||
| 
 | ||||
|   if (!market || !marketData) { | ||||
|     return null; | ||||
|   } | ||||
| 
 | ||||
|   let enactmentDate; | ||||
|   const proposal = proposalData?.proposal; | ||||
| 
 | ||||
|   if (proposal?.__typename === 'Proposal') { | ||||
|     enactmentDate = parseISO(proposal.terms.enactmentDatetime); | ||||
|   } else if (proposal?.__typename === 'BatchProposal') { | ||||
|     const change = proposal.batchTerms?.changes.find( | ||||
|       (c) => c?.change.__typename === 'NewMarket' | ||||
|     ); | ||||
|     enactmentDate = change ? parseISO(change.enactmentDatetime) : undefined; | ||||
|   } | ||||
| 
 | ||||
|   const compiledGrid = | ||||
|     !skipGrid && compileGridData(t, market, marketData, onSelect); | ||||
| 
 | ||||
|  | ||||
| @ -14,6 +14,8 @@ export function generateMarket(override?: PartialDeep<Market>): Market { | ||||
|     tickSize: '1', | ||||
|     marketTimestamps: { | ||||
|       __typename: 'MarketTimestamps', | ||||
|       proposed: '2024-01-02', | ||||
|       pending: '2024-01-01', | ||||
|       close: '', | ||||
|       open: '', | ||||
|     }, | ||||
|  | ||||
| @ -2,18 +2,21 @@ import { ExternalLink } from '@vegaprotocol/ui-toolkit'; | ||||
| import type { ComponentProps } from 'react'; | ||||
| import { ETHERSCAN_ADDRESS, ETHERSCAN_TX, useEtherscanLink } from '../hooks'; | ||||
| import { useT } from '../use-t'; | ||||
| import { getExternalChainLabel } from '../external-chain'; | ||||
| 
 | ||||
| export const EtherscanLink = ({ | ||||
|   address, | ||||
|   tx, | ||||
|   sourceChainId, | ||||
|   children, | ||||
|   ...props | ||||
| }: { | ||||
|   address?: string; | ||||
|   tx?: string; | ||||
|   sourceChainId?: number; | ||||
| } & ComponentProps<typeof ExternalLink>) => { | ||||
|   const t = useT(); | ||||
|   const etherscanLink = useEtherscanLink(); | ||||
|   const etherscanLink = useEtherscanLink(sourceChainId); | ||||
|   let href = ''; | ||||
| 
 | ||||
|   if ((!address && !tx) || (address && tx)) { | ||||
| @ -30,7 +33,13 @@ export const EtherscanLink = ({ | ||||
|   return ( | ||||
|     <ExternalLink | ||||
|       href={href} | ||||
|       title={t('View on Etherscan (opens in a new tab)')} | ||||
|       title={ | ||||
|         sourceChainId | ||||
|           ? t('View on {{chainLabel}} (opens in a new tab)', { | ||||
|               chainLabel: getExternalChainLabel(sourceChainId.toString()), | ||||
|             }) | ||||
|           : t('View on Etherscan (opens in a new tab)') | ||||
|       } | ||||
|       {...props} | ||||
|     > | ||||
|       {children || address || tx} | ||||
|  | ||||
| @ -10,7 +10,7 @@ export const SUPPORTED_CHAIN_LABELS: ChainIdMapping = { | ||||
|   '11155111': 'Sepolia', | ||||
| }; | ||||
| 
 | ||||
| export function getExternalExplorerLink(chainId: string, type: string) { | ||||
| export function getExternalExplorerLink(chainId: string) { | ||||
|   if (SUPPORTED_CHAIN_IDS.includes(chainId)) { | ||||
|     switch (chainId) { | ||||
|       case '1': | ||||
| @ -3,6 +3,7 @@ import { useCallback } from 'react'; | ||||
| import { Networks } from '../types'; | ||||
| import { ENV, useEnvironment } from './use-environment'; | ||||
| import { stripFullStops } from '@vegaprotocol/utils'; | ||||
| import { getExternalExplorerLink } from '../external-chain'; | ||||
| 
 | ||||
| const VEGA_DOCS_URL = | ||||
|   process.env['NX_VEGA_DOCS_URL'] || 'https://docs.vega.xyz/mainnet'; | ||||
| @ -119,9 +120,15 @@ export const useLinks = (dapp: DApp, network?: Net) => { | ||||
|   return link; | ||||
| }; | ||||
| 
 | ||||
| export const useEtherscanLink = () => { | ||||
| export const useEtherscanLink = (sourceChainId?: number) => { | ||||
|   const { ETHERSCAN_URL } = useEnvironment(); | ||||
|   const baseUrl = trim(ETHERSCAN_URL, '/'); | ||||
| 
 | ||||
|   const otherScanUrl = sourceChainId | ||||
|     ? getExternalExplorerLink(sourceChainId.toString()) | ||||
|     : undefined; | ||||
| 
 | ||||
|   const baseUrl = trim(otherScanUrl || ETHERSCAN_URL, '/'); | ||||
| 
 | ||||
|   const link = useCallback( | ||||
|     (url?: string) => `${baseUrl}/${trim(url, '/') || ''}`, | ||||
|     [baseUrl] | ||||
|  | ||||
| @ -12,3 +12,6 @@ export * from './utils/__generated__/NodeCheck'; | ||||
| 
 | ||||
| // Chain info
 | ||||
| export { CHAIN_IDS } from './chains'; | ||||
| 
 | ||||
| // External chain environments
 | ||||
| export * from './external-chain'; | ||||
|  | ||||
| @ -66,6 +66,8 @@ export const generateFill = (override?: PartialDeep<Trade>) => { | ||||
|       }, | ||||
|       marketTimestamps: { | ||||
|         __typename: 'MarketTimestamps', | ||||
|         proposed: '2005-03-31T19:37:00.000Z', | ||||
|         pending: '2005-04-01T19:37:00.000Z', | ||||
|         open: '2005-04-02T19:37:00.000Z', | ||||
|         close: '2005-04-02T19:37:00.000Z', | ||||
|       }, | ||||
|  | ||||
| @ -34,6 +34,8 @@ export const generateFundingPayment = ( | ||||
|       }, | ||||
|       marketTimestamps: { | ||||
|         __typename: 'MarketTimestamps', | ||||
|         proposed: '2005-03-31T19:37:00.000Z', | ||||
|         pending: '2005-04-01T19:37:00.000Z', | ||||
|         open: '2005-04-02T19:37:00.000Z', | ||||
|         close: '2005-04-02T19:37:00.000Z', | ||||
|       }, | ||||
|  | ||||
| @ -38,6 +38,7 @@ | ||||
|   "This app will only work on {{VEGA_ENV}}. Select a node to connect to.": "This app will only work on {{VEGA_ENV}}. Select a node to connect to.", | ||||
|   "VALIDATOR_TESTNET": "VALIDATOR_TESTNET", | ||||
|   "View on Etherscan (opens in a new tab)": "View on Etherscan (opens in a new tab)", | ||||
|   "View on {{chainLabel}} (opens in a new tab)": "View on {{chainLabel}} (opens in a new tab)", | ||||
|   "Warning delay ( >{{warningLatency}} sec): {{blockUpdateLatency}} sec": "Warning delay ( >{{warningLatency}} sec): {{blockUpdateLatency}} sec", | ||||
|   "Yes": "Yes" | ||||
| } | ||||
|  | ||||
| @ -144,6 +144,7 @@ | ||||
|   "View governance proposal": "View governance proposal", | ||||
|   "View liquidity provision table": "View liquidity provision table", | ||||
|   "View on Etherscan": "View on Etherscan", | ||||
|   "View on {{chainLabel}}": "View on {{chainLabel}}", | ||||
|   "View settlement data specification": "View settlement data specification", | ||||
|   "View settlement schedule specification": "View settlement schedule specification", | ||||
|   "View termination specification": "View termination specification", | ||||
|  | ||||
| @ -5,19 +5,14 @@ | ||||
|   "blocks": "blocks", | ||||
|   "Changes have been proposed for this asset.": "Changes have been proposed for this asset.", | ||||
|   "Changes have been proposed for this market.": "Changes have been proposed for this market.", | ||||
|   "Closing date": "Closing date", | ||||
|   "Confirm transaction in wallet": "Confirm transaction in wallet", | ||||
|   "Enactment date": "Enactment date", | ||||
|   "Enactment date: {{date}}": "Enactment date: {{date}}", | ||||
|   "estimated time to protocol upgrade": "estimated time to protocol upgrade", | ||||
|   "estimating...": "estimating...", | ||||
|   "Market": "Market", | ||||
|   "Network upgrade in {{countdown}}": "Network upgrade in {{countdown}}", | ||||
|   "No proposed markets": "No proposed markets", | ||||
|   "numberOfBlocks": "<0>{{count}}</0> blocks", | ||||
|   "numberOfBlocks_one": "<0>{{count}}</0> block", | ||||
|   "numberOfBlocks_other": "<0>{{count}}</0> blocks", | ||||
|   "Parent market": "Parent market", | ||||
|   "Please open your wallet application and confirm or reject the transaction": "Please open your wallet application and confirm or reject the transaction", | ||||
|   "Please wait for your transaction to be confirmed": "Please wait for your transaction to be confirmed", | ||||
|   "Proposal declined": "Proposal declined", | ||||
| @ -28,8 +23,6 @@ | ||||
|   "Proposal submitted": "Proposal submitted", | ||||
|   "Proposal waiting for node vote": "Proposal waiting for node vote", | ||||
|   "Rejection reason: {{reason}}": "Rejection reason: {{reason}}", | ||||
|   "Settlement asset": "Settlement asset", | ||||
|   "State": "State", | ||||
|   "Submission failed": "Submission failed", | ||||
|   "The network is being upgraded to {{vegaReleaseTag}}": "The network is being upgraded to {{vegaReleaseTag}}", | ||||
|   "The network will upgrade to {{vegaReleaseTag}} in {{countdown}}": "The network will upgrade to {{vegaReleaseTag}} in {{countdown}}", | ||||
| @ -41,7 +34,6 @@ | ||||
|   "Update <0>{{key}}</0> to {{value}}": "Update <0>{{key}}</0> to {{value}}", | ||||
|   "View details": "View details", | ||||
|   "View in block explorer": "View in block explorer", | ||||
|   "View proposal": "View proposal", | ||||
|   "View proposal details": "View proposal details", | ||||
|   "Voting": "Voting", | ||||
|   "Your transaction has been confirmed": "Your transaction has been confirmed" | ||||
|  | ||||
| @ -38,6 +38,7 @@ | ||||
|   "Close menu": "Close menu", | ||||
|   "Closed": "Closed", | ||||
|   "Closed markets": "Closed markets", | ||||
|   "Closing date": "Closing date", | ||||
|   "Code must be 64 characters in length": "Code must be 64 characters in length", | ||||
|   "Code must be be valid hex": "Code must be be valid hex", | ||||
|   "Collateral": "Collateral", | ||||
| @ -89,6 +90,7 @@ | ||||
|   "Edit alias": "Edit alias", | ||||
|   "Eligible teams": "Eligible teams", | ||||
|   "Enactment date reached and usual auction exit checks pass": "Enactment date reached and usual auction exit checks pass", | ||||
|   "Enactment date": "Enactment date", | ||||
|   "[empty]": "[empty]", | ||||
|   "Ends in": "Ends in", | ||||
|   "Entity scope": "Entity scope", | ||||
| @ -219,6 +221,7 @@ | ||||
|   "No orders": "No orders", | ||||
|   "No party accepts any liability for any losses whatsoever.": "No party accepts any liability for any losses whatsoever.", | ||||
|   "No perpetual markets.": "No perpetual markets.", | ||||
|   "No proposed markets": "No proposed markets", | ||||
|   "No referral program active": "No referral program active", | ||||
|   "No rejected orders": "No rejected orders", | ||||
|   "No rewards": "No rewards", | ||||
| @ -247,6 +250,7 @@ | ||||
|   "PRNT": "PRNT", | ||||
|   "Page not found": "Page not found", | ||||
|   "Parent of a market": "Parent of a market", | ||||
|   "Parent market": "Parent market", | ||||
|   "Pennant": "Pennant", | ||||
|   "Perpetuals": "Perpetuals", | ||||
|   "place_ordinal_one": "{{count}}st", | ||||
| @ -318,6 +322,7 @@ | ||||
|   "Staking multiplier": "Staking multiplier", | ||||
|   "Start trading": "Start trading", | ||||
|   "Start trading on the worlds most advanced decentralised exchange.": "Start trading on the worlds most advanced decentralised exchange.", | ||||
|   "State": "State", | ||||
|   "Status": "Status", | ||||
|   "Stop": "Stop", | ||||
|   "Stop orders": "Stop orders", | ||||
| @ -400,6 +405,7 @@ | ||||
|   "View oracle specification": "View oracle specification", | ||||
|   "View parent market": "View parent market", | ||||
|   "View proposals": "View proposals", | ||||
|   "View proposal": "View proposal", | ||||
|   "View settlement asset details": "View settlement asset details", | ||||
|   "View successor market": "View successor market", | ||||
|   "View team": "View team", | ||||
|  | ||||
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
							
								
								
									
										14
									
								
								libs/markets/src/lib/__generated__/markets.ts
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										14
									
								
								libs/markets/src/lib/__generated__/markets.ts
									
									
									
										generated
									
									
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							| @ -46,6 +46,7 @@ fragment DataSource on DataSourceSpec { | ||||
|                 operator | ||||
|               } | ||||
|             } | ||||
|             sourceChainId | ||||
|           } | ||||
|           ... on DataSourceSpecConfiguration { | ||||
|             signers { | ||||
| @ -153,6 +154,8 @@ query MarketInfo($marketId: ID!) { | ||||
|       } | ||||
|     } | ||||
|     marketTimestamps { | ||||
|       proposed | ||||
|       pending | ||||
|       open | ||||
|       close | ||||
|     } | ||||
|  | ||||
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							| @ -49,6 +49,7 @@ import { | ||||
|   LiquidityFeeMethodMappingDescription, | ||||
|   MarketStateMapping, | ||||
|   MarketTradingModeMapping, | ||||
|   type SuccessorConfiguration, | ||||
| } from '@vegaprotocol/types'; | ||||
| import { | ||||
|   DApp, | ||||
| @ -58,6 +59,7 @@ import { | ||||
|   useEnvironment, | ||||
|   useLinks, | ||||
|   DocsLinks, | ||||
|   getExternalChainLabel, | ||||
| } from '@vegaprotocol/environment'; | ||||
| import type { Provider } from '../../oracle-schema'; | ||||
| import { OracleBasicProfile } from '../../components/oracle-basic-profile'; | ||||
| @ -69,11 +71,7 @@ import { | ||||
|   useSuccessorMarketIdsQuery, | ||||
|   useSuccessorMarketQuery, | ||||
| } from '../../__generated__'; | ||||
| import { | ||||
|   useSuccessorMarketProposalDetailsQuery, | ||||
|   type SuccessorMarketProposalDetailsQuery, | ||||
|   type SingleProposal, | ||||
| } from '@vegaprotocol/proposals'; | ||||
| import { useSuccessorMarketProposalDetailsQuery } from '@vegaprotocol/proposals'; | ||||
| import { getQuoteName, getAsset } from '../../market-utils'; | ||||
| import classNames from 'classnames'; | ||||
| import compact from 'lodash/compact'; | ||||
| @ -254,15 +252,27 @@ export const KeyDetailsInfoPanel = ({ | ||||
|       skip: !featureFlags.SUCCESSOR_MARKETS || !market.proposal?.id, | ||||
|     }); | ||||
| 
 | ||||
|   const successorProposal = successorProposalDetails?.proposal as | ||||
|     | SingleProposal<SuccessorMarketProposalDetailsQuery['proposal']> | ||||
|     | undefined; | ||||
|   let successorConfiguration: SuccessorConfiguration | false = false; | ||||
| 
 | ||||
|   const successorConfiguration = | ||||
|     successorProposal?.terms.change.__typename === 'NewMarket' && | ||||
|     successorProposal.terms.change.successorConfiguration?.__typename === | ||||
|   if (successorProposalDetails?.proposal?.__typename === 'Proposal') { | ||||
|     successorConfiguration = | ||||
|       successorProposalDetails.proposal.terms.change.__typename === | ||||
|         'NewMarket' && | ||||
|       successorProposalDetails.proposal.terms.change.successorConfiguration | ||||
|         ?.__typename === 'SuccessorConfiguration' && | ||||
|       successorProposalDetails.proposal.terms.change.successorConfiguration; | ||||
|   } else if ( | ||||
|     successorProposalDetails?.proposal?.__typename === 'BatchProposal' | ||||
|   ) { | ||||
|     const subTerms = successorProposalDetails.proposal.batchTerms?.changes.find( | ||||
|       (c) => c?.change.__typename === 'NewMarket' | ||||
|     ); | ||||
|     successorConfiguration = | ||||
|       subTerms?.change.__typename === 'NewMarket' && | ||||
|       subTerms?.change.successorConfiguration?.__typename === | ||||
|         'SuccessorConfiguration' && | ||||
|     successorProposal.terms.change.successorConfiguration; | ||||
|       subTerms?.change?.successorConfiguration; | ||||
|   } | ||||
| 
 | ||||
|   // The following queries are needed as the parent market could also have been a successor market.
 | ||||
|   // Note: the parent market is only passed to this component if the successor markets flag is enabled,
 | ||||
| @ -281,9 +291,27 @@ export const KeyDetailsInfoPanel = ({ | ||||
|       }, | ||||
|       skip: !parentMarket?.proposal?.id, | ||||
|     }); | ||||
|   const parentProposal = parentSuccessorProposalDetails?.proposal as | ||||
|     | SingleProposal<SuccessorMarketProposalDetailsQuery['proposal']> | ||||
|     | undefined; | ||||
| 
 | ||||
|   let parentSuccessorConfig: SuccessorConfiguration | undefined = undefined; | ||||
| 
 | ||||
|   if (parentSuccessorProposalDetails?.proposal?.__typename === 'Proposal') { | ||||
|     const parentProposal = parentSuccessorProposalDetails?.proposal; | ||||
|     parentSuccessorConfig = | ||||
|       parentProposal.terms.change.__typename === 'NewMarket' | ||||
|         ? parentProposal.terms.change.successorConfiguration || undefined | ||||
|         : undefined; | ||||
|   } else if ( | ||||
|     parentSuccessorProposalDetails?.proposal?.__typename === 'BatchProposal' | ||||
|   ) { | ||||
|     const subTerms = | ||||
|       parentSuccessorProposalDetails.proposal.batchTerms?.changes.find( | ||||
|         (c) => c?.change.__typename === 'NewMarket' | ||||
|       ); | ||||
|     parentSuccessorConfig = | ||||
|       subTerms?.change.__typename === 'NewMarket' | ||||
|         ? subTerms.change.successorConfiguration || undefined | ||||
|         : undefined; | ||||
|   } | ||||
| 
 | ||||
|   const assetDecimals = getAsset(market).decimals; | ||||
| 
 | ||||
| @ -339,10 +367,7 @@ export const KeyDetailsInfoPanel = ({ | ||||
|           parentMarket && { | ||||
|             name: parentMarket?.tradableInstrument?.instrument?.name, | ||||
|             parentMarketID: grandparentMarketIdData?.market?.parentMarketID, | ||||
|             insurancePoolFraction: | ||||
|               parentProposal?.terms.change.__typename === 'NewMarket' && | ||||
|               parentProposal?.terms.change.successorConfiguration | ||||
|                 ?.insurancePoolFraction, | ||||
|             insurancePoolFraction: parentSuccessorConfig?.insurancePoolFraction, | ||||
|             status: | ||||
|               parentMarket?.state && MarketStateMapping[parentMarket.state], | ||||
|             tradingMode: | ||||
| @ -872,8 +897,15 @@ export const EthOraclePanel = ({ sourceType }: { sourceType: EthCallSpec }) => { | ||||
|           </KeyValueTable> | ||||
| 
 | ||||
|           <div className="my-2"> | ||||
|             <EtherscanLink address={sourceType.address}> | ||||
|               {t('View on Etherscan')} | ||||
|             <EtherscanLink | ||||
|               address={sourceType.address} | ||||
|               sourceChainId={sourceType.sourceChainId} | ||||
|             > | ||||
|               {t('View on {{chainLabel}}', { | ||||
|                 chainLabel: getExternalChainLabel( | ||||
|                   sourceType.sourceChainId.toString() | ||||
|                 ), | ||||
|               })} | ||||
|             </EtherscanLink> | ||||
|           </div> | ||||
|         </> | ||||
|  | ||||
| @ -27,6 +27,8 @@ export const marketInfoQuery = ( | ||||
|       linearSlippageFactor: '0.01', | ||||
|       marketTimestamps: { | ||||
|         __typename: 'MarketTimestamps', | ||||
|         proposed: '2022-11-13T02:15:24.543614154Z', | ||||
|         pending: '2022-11-14T02:15:24.543614154Z', | ||||
|         open: '2022-11-15T02:15:24.543614154Z', | ||||
|         close: null, | ||||
|       }, | ||||
|  | ||||
| @ -13,6 +13,8 @@ const MARKET_A: Partial<Market> = { | ||||
|   id: '1', | ||||
|   marketTimestamps: { | ||||
|     __typename: 'MarketTimestamps', | ||||
|     proposed: '2022-05-11T13:08:27.693537312Z', | ||||
|     pending: '2022-05-12T13:08:27.693537312Z', | ||||
|     open: '2022-05-18T13:08:27.693537312Z', | ||||
|     close: null, | ||||
|   }, | ||||
| @ -24,6 +26,8 @@ const MARKET_B: Partial<Market> = { | ||||
|   id: '2', | ||||
|   marketTimestamps: { | ||||
|     __typename: 'MarketTimestamps', | ||||
|     proposed: '2022-05-11T13:08:27.693537312Z', | ||||
|     pending: '2022-05-12T13:08:27.693537312Z', | ||||
|     open: '2022-05-18T13:00:39.328347732Z', | ||||
|     close: null, | ||||
|   }, | ||||
| @ -35,6 +39,8 @@ const MARKET_C: Partial<Market> = { | ||||
|   id: '3', | ||||
|   marketTimestamps: { | ||||
|     __typename: 'MarketTimestamps', | ||||
|     proposed: '2022-05-11T13:08:27.693537312Z', | ||||
|     pending: '2022-05-12T13:08:27.693537312Z', | ||||
|     open: '2022-05-17T13:00:39.328347732Z', | ||||
|     close: null, | ||||
|   }, | ||||
| @ -46,6 +52,8 @@ const MARKET_D: Partial<Market> = { | ||||
|   id: '4', | ||||
|   marketTimestamps: { | ||||
|     __typename: 'MarketTimestamps', | ||||
|     proposed: '2022-05-11T13:08:27.693537312Z', | ||||
|     pending: '2022-05-12T13:08:27.693537312Z', | ||||
|     open: '2022-05-16T13:00:39.328347732Z', | ||||
|     close: null, | ||||
|   }, | ||||
|  | ||||
| @ -123,6 +123,16 @@ export const filterAndSortClosedMarkets = (markets: MarketMaybeWithData[]) => { | ||||
|   }); | ||||
| }; | ||||
| 
 | ||||
| export const filterAndSortProposedMarkets = ( | ||||
|   markets: MarketMaybeWithData[] | ||||
| ) => { | ||||
|   return markets.filter((m) => { | ||||
|     return [MarketState.STATE_PROPOSED].includes( | ||||
|       m.data?.marketState || m.state | ||||
|     ); | ||||
|   }); | ||||
| }; | ||||
| 
 | ||||
| export const calcCandleLow = (candles: Candle[]): string | undefined => { | ||||
|   return candles | ||||
|     ?.reduce((acc: BigNumber, c) => { | ||||
|  | ||||
| @ -27,6 +27,7 @@ import * as Schema from '@vegaprotocol/types'; | ||||
| import { | ||||
|   filterAndSortClosedMarkets, | ||||
|   filterAndSortMarkets, | ||||
|   filterAndSortProposedMarkets, | ||||
| } from './market-utils'; | ||||
| import type { Candle } from './market-candles-provider'; | ||||
| 
 | ||||
| @ -114,6 +115,11 @@ export const closedMarketsProvider = makeDerivedDataProvider<Market[], never>( | ||||
|   ([markets]) => filterAndSortClosedMarkets(markets) | ||||
| ); | ||||
| 
 | ||||
| export const proposedMarketsProvider = makeDerivedDataProvider<Market[], never>( | ||||
|   [marketsProvider], | ||||
|   ([markets]) => filterAndSortProposedMarkets(markets) | ||||
| ); | ||||
| 
 | ||||
| export type MarketMaybeWithCandles = Market & { candles?: Candle[] }; | ||||
| 
 | ||||
| const addCandles = <T extends Market>( | ||||
| @ -241,3 +247,10 @@ export const useMarketList = () => { | ||||
|     reload, | ||||
|   }; | ||||
| }; | ||||
| 
 | ||||
| export const useProposedMarketsList = () => { | ||||
|   return useDataProvider({ | ||||
|     dataProvider: proposedMarketsProvider, | ||||
|     variables: undefined, | ||||
|   }); | ||||
| }; | ||||
|  | ||||
| @ -37,9 +37,19 @@ fragment MarketFields on Market { | ||||
|     } | ||||
|   } | ||||
|   marketTimestamps { | ||||
|     proposed | ||||
|     pending | ||||
|     open | ||||
|     close | ||||
|   } | ||||
|   marketProposal { | ||||
|     ... on Proposal { | ||||
|       id | ||||
|     } | ||||
|     ... on BatchProposal { | ||||
|       id | ||||
|     } | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| query Markets { | ||||
|  | ||||
| @ -40,8 +40,10 @@ export const createMarketFragment = ( | ||||
|     tickSize: '1', | ||||
|     marketTimestamps: { | ||||
|       __typename: 'MarketTimestamps', | ||||
|       close: null, | ||||
|       proposed: '2022-08-23T11:36:32.252490405Z', | ||||
|       pending: '2022-08-24T11:36:32.252490405Z', | ||||
|       open: null, | ||||
|       close: null, | ||||
|     }, | ||||
|     successorMarketID: null, | ||||
|     parentMarketID: null, | ||||
| @ -190,6 +192,9 @@ const marketFieldsFragments: MarketFieldsFragment[] = [ | ||||
|     tradingMode: Schema.MarketTradingMode.TRADING_MODE_MONITORING_AUCTION, | ||||
|     state: Schema.MarketState.STATE_SUSPENDED, | ||||
|     marketTimestamps: { | ||||
|       proposed: '2022-08-23T11:36:32.252490405Z', | ||||
|       pending: '2022-08-24T11:36:32.252490405Z', | ||||
|       open: '2022-08-25T11:36:32.252490405Z', | ||||
|       close: '2022-08-26T11:36:32.252490405Z', | ||||
|     }, | ||||
|     fees: { | ||||
| @ -220,6 +225,9 @@ const marketFieldsFragments: MarketFieldsFragment[] = [ | ||||
|   createMarketFragment({ | ||||
|     id: 'market-3', | ||||
|     marketTimestamps: { | ||||
|       proposed: '2022-08-23T11:36:32.252490405Z', | ||||
|       pending: '2022-08-24T11:36:32.252490405Z', | ||||
|       open: '2022-08-25T11:36:32.252490405Z', | ||||
|       close: '2022-08-26T11:36:32.252490405Z', | ||||
|     }, | ||||
|     fees: { | ||||
|  | ||||
| @ -23,8 +23,10 @@ export const generateOrder = (partialOrder?: PartialDeep<Order>) => { | ||||
|       }, | ||||
|       marketTimestamps: { | ||||
|         __typename: 'MarketTimestamps', | ||||
|         close: '', | ||||
|         open: '', | ||||
|         proposed: '2022-08-23T11:36:32.252490405Z', | ||||
|         pending: '2022-08-24T11:36:32.252490405Z', | ||||
|         open: null, | ||||
|         close: null, | ||||
|       }, | ||||
|       positionDecimalPlaces: 2, | ||||
|       state: Schema.MarketState.STATE_ACTIVE, | ||||
|  | ||||
| @ -33,6 +33,8 @@ export const generateStopOrder = ( | ||||
|       }, | ||||
|       marketTimestamps: { | ||||
|         __typename: 'MarketTimestamps', | ||||
|         proposed: '2005-04-02T19:37:00.000Z', | ||||
|         pending: '2005-04-03T19:37:00.000Z', | ||||
|         close: '', | ||||
|         open: '', | ||||
|       }, | ||||
|  | ||||
| @ -117,6 +117,8 @@ describe('OrderViewDialog', () => { | ||||
|         }, | ||||
|         marketTimestamps: { | ||||
|           __typename: 'MarketTimestamps', | ||||
|           proposed: '2023-07-17T12:05:25.822854221Z', | ||||
|           pending: '2023-07-18T12:05:25.822854221Z', | ||||
|           open: '2023-07-19T12:05:25.822854221Z', | ||||
|           close: null, | ||||
|         }, | ||||
|  | ||||
| @ -1,6 +1,5 @@ | ||||
| export * from './asset-proposal-notification'; | ||||
| export * from './market-proposal-notification'; | ||||
| export * from './proposals-list'; | ||||
| export * from './protocol-upgrade-countdown'; | ||||
| export * from './protocol-upgrade-in-progress-notification'; | ||||
| export * from './protocol-upgrade-proposal-notification'; | ||||
|  | ||||
| @ -1 +0,0 @@ | ||||
| export * from './proposals-list'; | ||||
| @ -1,56 +0,0 @@ | ||||
| import type { FC } from 'react'; | ||||
| import { AgGrid } from '@vegaprotocol/datagrid'; | ||||
| import * as Types from '@vegaprotocol/types'; | ||||
| import { removePaginationWrapper } from '@vegaprotocol/utils'; | ||||
| import type { ProposalListFieldsFragment } from '../../lib/proposals-data-provider/__generated__/Proposals'; | ||||
| import { useProposalsListQuery } from '../../lib/proposals-data-provider/__generated__/Proposals'; | ||||
| import { useColumnDefs } from './use-column-defs'; | ||||
| import { useT } from '../../use-t'; | ||||
| 
 | ||||
| export const getNewMarketProposals = (data: ProposalListFieldsFragment[]) => | ||||
|   data.filter((proposal) => | ||||
|     [ | ||||
|       Types.ProposalState.STATE_OPEN, | ||||
|       Types.ProposalState.STATE_PASSED, | ||||
|       Types.ProposalState.STATE_WAITING_FOR_NODE_VOTE, | ||||
|     ].includes(proposal.state) | ||||
|   ); | ||||
| 
 | ||||
| const defaultColDef = { | ||||
|   sortable: true, | ||||
|   filter: true, | ||||
|   resizable: true, | ||||
|   filterParams: { buttons: ['reset'] }, | ||||
| }; | ||||
| 
 | ||||
| interface ProposalListProps { | ||||
|   cellRenderers: { | ||||
|     [name: string]: FC<{ value: string; data: ProposalListFieldsFragment }>; | ||||
|   }; | ||||
| } | ||||
| 
 | ||||
| export const ProposalsList = ({ cellRenderers }: ProposalListProps) => { | ||||
|   const t = useT(); | ||||
|   const { data } = useProposalsListQuery({ | ||||
|     variables: { | ||||
|       proposalType: Types.ProposalType.TYPE_NEW_MARKET, | ||||
|     }, | ||||
|     errorPolicy: 'all', // currently there are some proposals failing due to proposals existing without settlement asset ids
 | ||||
|   }); | ||||
|   const filteredData = getNewMarketProposals( | ||||
|     removePaginationWrapper(data?.proposalsConnection?.edges) | ||||
|   ); | ||||
|   const columnDefs = useColumnDefs(); | ||||
| 
 | ||||
|   return ( | ||||
|     <AgGrid | ||||
|       columnDefs={columnDefs} | ||||
|       rowData={filteredData} | ||||
|       defaultColDef={defaultColDef} | ||||
|       getRowId={({ data }) => data.id} | ||||
|       overlayNoRowsTemplate={t('No proposed markets')} | ||||
|       components={cellRenderers} | ||||
|       rowHeight={45} | ||||
|     /> | ||||
|   ); | ||||
| }; | ||||
| @ -1,2 +1,3 @@ | ||||
| export * from './proposals-data-provider'; | ||||
| export * from './__generated__/Proposals'; | ||||
| export * from './proposals.mock'; | ||||
|  | ||||
| @ -47,14 +47,10 @@ query ProposalOfMarket($marketId: ID!) { | ||||
|     } | ||||
|     ... on BatchProposal { | ||||
|       id | ||||
|       batchTerms { | ||||
|         changes { | ||||
|       subProposals { | ||||
|         id | ||||
|         terms { | ||||
|           enactmentDatetime | ||||
|           change { | ||||
|             ... on NewMarket { | ||||
|               __typename | ||||
|             } | ||||
|           } | ||||
|         } | ||||
|       } | ||||
|     } | ||||
| @ -76,6 +72,22 @@ query SuccessorMarketProposalDetails($proposalId: ID!) { | ||||
|         } | ||||
|       } | ||||
|     } | ||||
|     ... on BatchProposal { | ||||
|       id | ||||
|       batchTerms { | ||||
|         changes { | ||||
|           change { | ||||
|             ... on NewMarket { | ||||
|               __typename | ||||
|               successorConfiguration { | ||||
|                 parentMarketId | ||||
|                 insurancePoolFraction | ||||
|               } | ||||
|             } | ||||
|           } | ||||
|         } | ||||
|       } | ||||
|     } | ||||
|   } | ||||
| } | ||||
| 
 | ||||
|  | ||||
| @ -25,14 +25,14 @@ export type ProposalOfMarketQueryVariables = Types.Exact<{ | ||||
| }>; | ||||
| 
 | ||||
| 
 | ||||
| export type ProposalOfMarketQuery = { __typename?: 'Query', proposal?: { __typename?: 'BatchProposal', id?: string | null, batchTerms?: { __typename?: 'BatchProposalTerms', changes: Array<{ __typename?: 'BatchProposalTermsChange', enactmentDatetime?: any | null, change: { __typename?: 'CancelTransfer' } | { __typename?: 'NewAsset' } | { __typename?: 'NewFreeform' } | { __typename: 'NewMarket' } | { __typename?: 'NewSpotMarket' } | { __typename?: 'NewTransfer' } | { __typename?: 'UpdateAsset' } | { __typename?: 'UpdateMarket' } | { __typename?: 'UpdateMarketState' } | { __typename?: 'UpdateNetworkParameter' } | { __typename?: 'UpdateReferralProgram' } | { __typename?: 'UpdateSpotMarket' } | { __typename?: 'UpdateVolumeDiscountProgram' } } | null> } | null } | { __typename?: 'Proposal', id?: string | null, terms: { __typename?: 'ProposalTerms', enactmentDatetime?: any | null } } | null }; | ||||
| export type ProposalOfMarketQuery = { __typename?: 'Query', proposal?: { __typename?: 'BatchProposal', id?: string | null, subProposals?: Array<{ __typename?: 'ProposalDetail', id?: string | null, terms?: { __typename?: 'ProposalTerms', enactmentDatetime?: any | null } | null } | null> | null } | { __typename?: 'Proposal', id?: string | null, terms: { __typename?: 'ProposalTerms', enactmentDatetime?: any | null } } | null }; | ||||
| 
 | ||||
| export type SuccessorMarketProposalDetailsQueryVariables = Types.Exact<{ | ||||
|   proposalId: Types.Scalars['ID']; | ||||
| }>; | ||||
| 
 | ||||
| 
 | ||||
| export type SuccessorMarketProposalDetailsQuery = { __typename?: 'Query', proposal?: { __typename?: 'BatchProposal' } | { __typename?: 'Proposal', id?: string | null, terms: { __typename?: 'ProposalTerms', change: { __typename?: 'CancelTransfer' } | { __typename?: 'NewAsset' } | { __typename?: 'NewFreeform' } | { __typename?: 'NewMarket', successorConfiguration?: { __typename?: 'SuccessorConfiguration', parentMarketId: string, insurancePoolFraction: string } | null } | { __typename?: 'NewSpotMarket' } | { __typename?: 'NewTransfer' } | { __typename?: 'UpdateAsset' } | { __typename?: 'UpdateMarket' } | { __typename?: 'UpdateMarketState' } | { __typename?: 'UpdateNetworkParameter' } | { __typename?: 'UpdateReferralProgram' } | { __typename?: 'UpdateSpotMarket' } | { __typename?: 'UpdateVolumeDiscountProgram' } } } | null }; | ||||
| export type SuccessorMarketProposalDetailsQuery = { __typename?: 'Query', proposal?: { __typename?: 'BatchProposal', id?: string | null, batchTerms?: { __typename?: 'BatchProposalTerms', changes: Array<{ __typename?: 'BatchProposalTermsChange', change: { __typename?: 'CancelTransfer' } | { __typename?: 'NewAsset' } | { __typename?: 'NewFreeform' } | { __typename: 'NewMarket', successorConfiguration?: { __typename?: 'SuccessorConfiguration', parentMarketId: string, insurancePoolFraction: string } | null } | { __typename?: 'NewSpotMarket' } | { __typename?: 'NewTransfer' } | { __typename?: 'UpdateAsset' } | { __typename?: 'UpdateMarket' } | { __typename?: 'UpdateMarketState' } | { __typename?: 'UpdateNetworkParameter' } | { __typename?: 'UpdateReferralProgram' } | { __typename?: 'UpdateSpotMarket' } | { __typename?: 'UpdateVolumeDiscountProgram' } } | null> } | null } | { __typename?: 'Proposal', id?: string | null, terms: { __typename?: 'ProposalTerms', change: { __typename?: 'CancelTransfer' } | { __typename?: 'NewAsset' } | { __typename?: 'NewFreeform' } | { __typename?: 'NewMarket', successorConfiguration?: { __typename?: 'SuccessorConfiguration', parentMarketId: string, insurancePoolFraction: string } | null } | { __typename?: 'NewSpotMarket' } | { __typename?: 'NewTransfer' } | { __typename?: 'UpdateAsset' } | { __typename?: 'UpdateMarket' } | { __typename?: 'UpdateMarketState' } | { __typename?: 'UpdateNetworkParameter' } | { __typename?: 'UpdateReferralProgram' } | { __typename?: 'UpdateSpotMarket' } | { __typename?: 'UpdateVolumeDiscountProgram' } } } | null }; | ||||
| 
 | ||||
| export type InstrumentDetailsQueryVariables = Types.Exact<{ | ||||
|   marketId: Types.Scalars['ID']; | ||||
| @ -154,14 +154,10 @@ export const ProposalOfMarketDocument = gql` | ||||
|     } | ||||
|     ... on BatchProposal { | ||||
|       id | ||||
|       batchTerms { | ||||
|         changes { | ||||
|       subProposals { | ||||
|         id | ||||
|         terms { | ||||
|           enactmentDatetime | ||||
|           change { | ||||
|             ... on NewMarket { | ||||
|               __typename | ||||
|             } | ||||
|           } | ||||
|         } | ||||
|       } | ||||
|     } | ||||
| @ -212,6 +208,22 @@ export const SuccessorMarketProposalDetailsDocument = gql` | ||||
|         } | ||||
|       } | ||||
|     } | ||||
|     ... on BatchProposal { | ||||
|       id | ||||
|       batchTerms { | ||||
|         changes { | ||||
|           change { | ||||
|             ... on NewMarket { | ||||
|               __typename | ||||
|               successorConfiguration { | ||||
|                 parentMarketId | ||||
|                 insurancePoolFraction | ||||
|               } | ||||
|             } | ||||
|           } | ||||
|         } | ||||
|       } | ||||
|     } | ||||
|   } | ||||
| } | ||||
|     `;
 | ||||
|  | ||||
| @ -31,12 +31,26 @@ export interface SparklineProps { | ||||
| } | ||||
| 
 | ||||
| export const SparklineView = ({ | ||||
|   data, | ||||
|   data: rawData, | ||||
|   width = 60, | ||||
|   height = 15, | ||||
|   points = 24, | ||||
|   className, | ||||
| }: SparklineProps) => { | ||||
|   // Value can come in as 0, due to candle.close being empty string ''
 | ||||
|   // Instead of skewing the sparkline with 0 values, we map over and set any
 | ||||
|   // 0 values to the last non 0 value resulting in a better sparkline
 | ||||
|   let lastClose = 0; | ||||
|   const data = rawData.map((val) => { | ||||
|     if (val === 0) { | ||||
|       return lastClose; | ||||
|     } else { | ||||
|       lastClose = val; | ||||
|     } | ||||
| 
 | ||||
|     return val; | ||||
|   }); | ||||
| 
 | ||||
|   // Get the extent for our y value
 | ||||
|   const [min, max] = extent(data, (d) => d); | ||||
| 
 | ||||
|  | ||||
| @ -1,18 +1,16 @@ | ||||
| import BigNumber from 'bignumber.js'; | ||||
| 
 | ||||
| export const priceChangePercentage = (candles: string[]) => { | ||||
|   if (!candles.length) { | ||||
|     return 0; | ||||
|   } | ||||
| 
 | ||||
|   const change = priceChange(candles); | ||||
|   if (change && candles && candles.length > 0) { | ||||
|     const yesterdayLastPrice = candles[0] && BigInt(candles[0]); | ||||
|     if (yesterdayLastPrice) { | ||||
| 
 | ||||
|   return new BigNumber(change.toString()) | ||||
|         .dividedBy(new BigNumber(yesterdayLastPrice.toString())) | ||||
|     .dividedBy(new BigNumber(candles[0])) | ||||
|     .multipliedBy(100) | ||||
|     .toNumber(); | ||||
|     } | ||||
|     return 0; | ||||
|   } | ||||
|   return 0; | ||||
| }; | ||||
| 
 | ||||
| export const priceChange = (candles: string[]) => { | ||||
|  | ||||
| @ -217,6 +217,8 @@ describe('WithdrawFormContainer', () => { | ||||
|           }, | ||||
|           marketTimestamps: { | ||||
|             __typename: 'MarketTimestamps', | ||||
|             proposed: '2022-10-23T18:17:59.149283671Z', | ||||
|             pending: '2022-10-24T18:17:59.149283671Z', | ||||
|             open: '2022-10-25T18:17:59.149283671Z', | ||||
|             close: null, | ||||
|           }, | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user