mirror of
https://github.com/oceanprotocol/react.git
synced 2025-01-05 11:25:18 +01:00
use token name instead of DT
This commit is contained in:
parent
06ef2746f4
commit
40929faedf
@ -7,7 +7,7 @@ import { Metadata } from '@oceanprotocol/lib/dist/node/ddo/interfaces/Metadata'
|
|||||||
|
|
||||||
export function Publish() {
|
export function Publish() {
|
||||||
const { publish, publishStepText, isLoading } = usePublish()
|
const { publish, publishStepText, isLoading } = usePublish()
|
||||||
const { createPricing, buyDT, sellDT, pricingStep, pricingStepText, isLoading: pricingIsLoading, pricingError} = usePricing()
|
const { createPricing, buyDT, sellDT, pricingStep, pricingStepText, pricingIsLoading, pricingError} = usePricing()
|
||||||
const [ddo, setDdo] = useState<DDO | undefined | null>()
|
const [ddo, setDdo] = useState<DDO | undefined | null>()
|
||||||
|
|
||||||
const asset = {
|
const asset = {
|
||||||
|
@ -22,7 +22,7 @@ interface UsePricing {
|
|||||||
pricingStep?: number
|
pricingStep?: number
|
||||||
pricingStepText?: string
|
pricingStepText?: string
|
||||||
pricingError?: string
|
pricingError?: string
|
||||||
isLoading: boolean
|
pricingIsLoading: boolean
|
||||||
}
|
}
|
||||||
|
|
||||||
export const buyDTFeedback: { [key in number]: string } = {
|
export const buyDTFeedback: { [key in number]: string } = {
|
||||||
@ -45,22 +45,40 @@ export const createPricingFeedback: { [key in number]: string } = {
|
|||||||
|
|
||||||
function usePricing(): UsePricing {
|
function usePricing(): UsePricing {
|
||||||
const { ocean, status, account, accountId, config } = useOcean()
|
const { ocean, status, account, accountId, config } = useOcean()
|
||||||
const [isLoading, setIsLoading] = useState(false)
|
const [pricingIsLoading, setPricingIsLoading] = useState(false)
|
||||||
const [pricingStep, setPricingStep] = useState<number | undefined>()
|
const [pricingStep, setPricingStep] = useState<number | undefined>()
|
||||||
const [pricingStepText, setPricingStepText] = useState<string | undefined>()
|
const [pricingStepText, setPricingStepText] = useState<string | undefined>()
|
||||||
const [pricingError, setPricingError] = useState<string | undefined>()
|
const [pricingError, setPricingError] = useState<string | undefined>()
|
||||||
|
|
||||||
function setStepBuyDT(index?: number) {
|
function setStepBuyDT(index?: number, datatokenName?: string) {
|
||||||
setPricingStep(index)
|
setPricingStep(index)
|
||||||
index && setPricingStepText(buyDTFeedback[index])
|
let message
|
||||||
|
if (index) {
|
||||||
|
if (datatokenName)
|
||||||
|
message = buyDTFeedback[index].replace(/DT/g, datatokenName)
|
||||||
|
else message = buyDTFeedback[index]
|
||||||
|
setPricingStepText(message)
|
||||||
}
|
}
|
||||||
function setStepSellDT(index?: number) {
|
|
||||||
setPricingStep(index)
|
|
||||||
index && setPricingStepText(sellDTFeedback[index])
|
|
||||||
}
|
}
|
||||||
function setStepCreatePricing(index?: number) {
|
function setStepSellDT(index?: number, datatokenName?: string) {
|
||||||
setPricingStep(index)
|
setPricingStep(index)
|
||||||
index && setPricingStepText(createPricingFeedback[index])
|
let message
|
||||||
|
if (index) {
|
||||||
|
if (datatokenName)
|
||||||
|
message = sellDTFeedback[index].replace(/DT/g, datatokenName)
|
||||||
|
else message = sellDTFeedback[index]
|
||||||
|
setPricingStepText(message)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
function setStepCreatePricing(index?: number, datatokenName?: string) {
|
||||||
|
setPricingStep(index)
|
||||||
|
let message
|
||||||
|
if (index) {
|
||||||
|
if (datatokenName)
|
||||||
|
message = createPricingFeedback[index].replace(/DT/g, datatokenName)
|
||||||
|
else message = createPricingFeedback[index]
|
||||||
|
setPricingStepText(message)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
async function createPricing(
|
async function createPricing(
|
||||||
@ -68,9 +86,13 @@ function usePricing(): UsePricing {
|
|||||||
priceOptions: PriceOptions
|
priceOptions: PriceOptions
|
||||||
): Promise<TransactionReceipt | string | null> {
|
): Promise<TransactionReceipt | string | null> {
|
||||||
if (!ocean || !account || !accountId) return null
|
if (!ocean || !account || !accountId) return null
|
||||||
setStepCreatePricing(0)
|
|
||||||
let response = null
|
let response = null
|
||||||
try {
|
try {
|
||||||
|
setPricingIsLoading(true)
|
||||||
|
setPricingError(undefined)
|
||||||
|
const datatokenName = await ocean.datatokens.getName(dataTokenAddress)
|
||||||
|
setStepCreatePricing(0, datatokenName)
|
||||||
switch (priceOptions.type) {
|
switch (priceOptions.type) {
|
||||||
case 'dynamic': {
|
case 'dynamic': {
|
||||||
setStepCreatePricing(2)
|
setStepCreatePricing(2)
|
||||||
@ -112,7 +134,7 @@ function usePricing(): UsePricing {
|
|||||||
} finally {
|
} finally {
|
||||||
setPricingStep(undefined)
|
setPricingStep(undefined)
|
||||||
setPricingStepText(undefined)
|
setPricingStepText(undefined)
|
||||||
setIsLoading(false)
|
setPricingIsLoading(false)
|
||||||
}
|
}
|
||||||
return null
|
return null
|
||||||
}
|
}
|
||||||
@ -123,17 +145,17 @@ function usePricing(): UsePricing {
|
|||||||
): Promise<TransactionReceipt | null> {
|
): Promise<TransactionReceipt | null> {
|
||||||
if (!ocean || !account || !accountId) return null
|
if (!ocean || !account || !accountId) return null
|
||||||
|
|
||||||
setIsLoading(true)
|
try {
|
||||||
|
const datatokenName = await ocean.datatokens.getName(dataTokenAddress)
|
||||||
|
setPricingIsLoading(true)
|
||||||
setPricingError(undefined)
|
setPricingError(undefined)
|
||||||
setStepBuyDT(0)
|
setStepBuyDT(0)
|
||||||
|
|
||||||
try {
|
|
||||||
const bestPrice = await getBestDataTokenPrice(ocean, dataTokenAddress)
|
const bestPrice = await getBestDataTokenPrice(ocean, dataTokenAddress)
|
||||||
switch (bestPrice?.type) {
|
switch (bestPrice?.type) {
|
||||||
case 'pool': {
|
case 'pool': {
|
||||||
const price = new Decimal(bestPrice.value).times(1.05).toString()
|
const price = new Decimal(bestPrice.value).times(1.05).toString()
|
||||||
const maxPrice = new Decimal(bestPrice.value).times(2).toString()
|
const maxPrice = new Decimal(bestPrice.value).times(2).toString()
|
||||||
setStepBuyDT(1)
|
setStepBuyDT(1, datatokenName)
|
||||||
Logger.log(
|
Logger.log(
|
||||||
'Buying token from pool',
|
'Buying token from pool',
|
||||||
bestPrice,
|
bestPrice,
|
||||||
@ -167,7 +189,7 @@ function usePricing(): UsePricing {
|
|||||||
bestPrice.value.toString(),
|
bestPrice.value.toString(),
|
||||||
account.getId()
|
account.getId()
|
||||||
)
|
)
|
||||||
setStepBuyDT(1)
|
setStepBuyDT(1, datatokenName)
|
||||||
const exchange = await ocean.fixedRateExchange.buyDT(
|
const exchange = await ocean.fixedRateExchange.buyDT(
|
||||||
bestPrice.address,
|
bestPrice.address,
|
||||||
String(dtAmount),
|
String(dtAmount),
|
||||||
@ -184,7 +206,7 @@ function usePricing(): UsePricing {
|
|||||||
} finally {
|
} finally {
|
||||||
setPricingStep(undefined)
|
setPricingStep(undefined)
|
||||||
setPricingStepText(undefined)
|
setPricingStepText(undefined)
|
||||||
setIsLoading(false)
|
setPricingIsLoading(false)
|
||||||
}
|
}
|
||||||
return null
|
return null
|
||||||
}
|
}
|
||||||
@ -198,15 +220,15 @@ function usePricing(): UsePricing {
|
|||||||
Logger.error(`'oceanTokenAddress' not set in config`)
|
Logger.error(`'oceanTokenAddress' not set in config`)
|
||||||
return null
|
return null
|
||||||
}
|
}
|
||||||
setIsLoading(true)
|
|
||||||
setPricingError(undefined)
|
|
||||||
setStepSellDT(0)
|
|
||||||
|
|
||||||
try {
|
try {
|
||||||
|
const datatokenName = await ocean.datatokens.getName(dataTokenAddress)
|
||||||
|
setPricingIsLoading(true)
|
||||||
|
setPricingError(undefined)
|
||||||
|
setStepSellDT(0, datatokenName)
|
||||||
const pool = await getFirstPool(ocean, dataTokenAddress)
|
const pool = await getFirstPool(ocean, dataTokenAddress)
|
||||||
if (!pool || pool.price === 0) return null
|
if (!pool || pool.price === 0) return null
|
||||||
const price = new Decimal(pool.price).times(0.95).toString()
|
const price = new Decimal(pool.price).times(0.95).toString()
|
||||||
setStepSellDT(1)
|
setStepSellDT(1, datatokenName)
|
||||||
Logger.log('Selling token to pool', pool, account.getId(), price)
|
Logger.log('Selling token to pool', pool, account.getId(), price)
|
||||||
const sellResponse = await ocean.pool.sellDT(
|
const sellResponse = await ocean.pool.sellDT(
|
||||||
account.getId(),
|
account.getId(),
|
||||||
@ -223,7 +245,7 @@ function usePricing(): UsePricing {
|
|||||||
} finally {
|
} finally {
|
||||||
setStepSellDT(undefined)
|
setStepSellDT(undefined)
|
||||||
setPricingStepText(undefined)
|
setPricingStepText(undefined)
|
||||||
setIsLoading(false)
|
setPricingIsLoading(false)
|
||||||
}
|
}
|
||||||
return null
|
return null
|
||||||
}
|
}
|
||||||
@ -234,7 +256,7 @@ function usePricing(): UsePricing {
|
|||||||
sellDT,
|
sellDT,
|
||||||
pricingStep,
|
pricingStep,
|
||||||
pricingStepText,
|
pricingStepText,
|
||||||
isLoading,
|
pricingIsLoading,
|
||||||
pricingError
|
pricingError
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user