Browse Source

Show cfd expiry in UI

feature/actor-custom-derive
Philipp Hoenisch 3 years ago
parent
commit
0a51601a6d
No known key found for this signature in database GPG Key ID: E5F8E74C672BC666
  1. 4
      daemon/src/model.rs
  2. 6
      daemon/src/model/cfd.rs
  3. 5
      daemon/src/to_sse_event.rs
  4. 1
      frontend/src/components/Types.tsx
  5. 10
      frontend/src/components/cfdtables/CfdTable.tsx

4
daemon/src/model.rs

@ -207,6 +207,10 @@ impl BitMexPriceEventId {
.join(&self.to_string()) .join(&self.to_string())
.expect("Event id can be joined") .expect("Event id can be joined")
} }
pub fn timestamp(&self) -> OffsetDateTime {
self.timestamp
}
} }
impl fmt::Display for BitMexPriceEventId { impl fmt::Display for BitMexPriceEventId {

6
daemon/src/model/cfd.rs

@ -17,7 +17,7 @@ use std::collections::HashMap;
use std::fmt; use std::fmt;
use std::ops::{Neg, RangeInclusive}; use std::ops::{Neg, RangeInclusive};
use std::time::SystemTime; use std::time::SystemTime;
use time::Duration; use time::{Duration, OffsetDateTime};
use uuid::adapter::Hyphenated; use uuid::adapter::Hyphenated;
use uuid::Uuid; use uuid::Uuid;
@ -689,6 +689,10 @@ impl Cfd {
(self.order.term * Cfd::REFUND_THRESHOLD).as_blocks().ceil() as u32 (self.order.term * Cfd::REFUND_THRESHOLD).as_blocks().ceil() as u32
} }
pub fn expiry_timestamp(&self) -> OffsetDateTime {
self.order.oracle_event_id.timestamp()
}
/// A factor to be added to the CFD order term for calculating the refund timelock. /// A factor to be added to the CFD order term for calculating the refund timelock.
/// ///
/// The refund timelock is important in case the oracle disappears or never publishes a /// The refund timelock is important in case the oracle disappears or never publishes a

5
daemon/src/to_sse_event.rs

@ -10,6 +10,7 @@ use rust_decimal::Decimal;
use serde::{Deserialize, Serialize}; use serde::{Deserialize, Serialize};
use std::convert::TryInto; use std::convert::TryInto;
use std::time::{SystemTime, UNIX_EPOCH}; use std::time::{SystemTime, UNIX_EPOCH};
use time::OffsetDateTime;
use tokio::sync::watch; use tokio::sync::watch;
#[derive(Debug, Clone, Serialize)] #[derive(Debug, Clone, Serialize)]
@ -38,6 +39,9 @@ pub struct Cfd {
pub state_transition_timestamp: u64, pub state_transition_timestamp: u64,
pub details: CfdDetails, pub details: CfdDetails,
#[serde(with = "::time::serde::timestamp")]
pub expiry_timestamp: OffsetDateTime,
} }
#[derive(Debug, Clone, Serialize)] #[derive(Debug, Clone, Serialize)]
@ -261,6 +265,7 @@ impl ToSseEvent for CfdsWithAuxData {
margin: cfd.margin().unwrap(), margin: cfd.margin().unwrap(),
margin_counterparty: cfd.counterparty_margin().unwrap(), margin_counterparty: cfd.counterparty_margin().unwrap(),
details, details,
expiry_timestamp: cfd.expiry_timestamp(),
} }
}) })
.collect::<Vec<Cfd>>(); .collect::<Vec<Cfd>>();

1
frontend/src/components/Types.tsx

@ -49,6 +49,7 @@ export interface Cfd {
actions: Action[]; actions: Action[];
state_transition_timestamp: number; state_transition_timestamp: number;
details: CfdDetails; details: CfdDetails;
expiry_timestamp: number;
} }
export interface CfdDetails { export interface CfdDetails {

10
frontend/src/components/cfdtables/CfdTable.tsx

@ -20,6 +20,7 @@ import {
Table as CUITable, Table as CUITable,
Tbody, Tbody,
Td, Td,
Text,
Th, Th,
Thead, Thead,
Tooltip, Tooltip,
@ -30,6 +31,7 @@ import {
import React from "react"; import React from "react";
import { useAsync } from "react-async"; import { useAsync } from "react-async";
import { Column, Row, useExpanded, useSortBy, useTable } from "react-table"; import { Column, Row, useExpanded, useSortBy, useTable } from "react-table";
import Timestamp from "../Timestamp";
import { Action, Cfd } from "../Types"; import { Action, Cfd } from "../Types";
interface CfdTableProps { interface CfdTableProps {
@ -95,7 +97,7 @@ export function CfdTable(
}, },
{ {
Header: "Details", Header: "Details",
accessor: ({ details }) => { accessor: ({ details, expiry_timestamp }) => {
const txs = details.tx_url_list.map((tx) => { const txs = details.tx_url_list.map((tx) => {
return (<Link href={tx.url} key={tx.url} isExternal> return (<Link href={tx.url} key={tx.url} isExternal>
{tx.label + " transaction"} {tx.label + " transaction"}
@ -108,6 +110,10 @@ export function CfdTable(
<VStack> <VStack>
{txs} {txs}
{details.payout && <Box>Payout: {details.payout}</Box>} {details.payout && <Box>Payout: {details.payout}</Box>}
<HStack>
<Text>Expires on:</Text>
<Timestamp timestamp={expiry_timestamp} />
</HStack>
</VStack> </VStack>
</Box> </Box>
); );
@ -260,7 +266,7 @@ function colorSchemaForAction(action: Action): string {
function renderRowSubComponent(row: Row<Cfd>) { function renderRowSubComponent(row: Row<Cfd>) {
let cells = row.allCells let cells = row.allCells
.filter((cell) => { .filter((cell) => {
return ["Details"].includes(cell.column.id); return ["Details", "Timestamp"].includes(cell.column.id);
}) })
.map((cell) => { .map((cell) => {
return cell; return cell;

Loading…
Cancel
Save