blockchainethereumblockchain-walleterc20erc721walletxdaidappdecentralizederc1155erc875iosswifttokens
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
1041 lines
103 KiB
1041 lines
103 KiB
<?xml version="1.0" encoding="UTF-8" standalone="no"?><ts:token xmlns:ts="http://tokenscript.org/2020/06/tokenscript" xmlns:asnx="urn:ietf:params:xml:ns:asnx" xmlns:ethereum="urn:ethereum:constantinople" xmlns:xhtml="http://www.w3.org/1999/xhtml" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" custodian="false" xsi:schemaLocation="http://tokenscript.org/2020/06/tokenscript http://tokenscript.org/2020/06/tokenscript.xsd">
|
|
|
|
<asnx:module name="aDAIEvents">
|
|
<namedType name="Repay">
|
|
<type>
|
|
<sequence>
|
|
<element ethereum:indexed="true" ethereum:type="address" name="_reserve"/>
|
|
<element ethereum:indexed="true" ethereum:type="address" name="_user"/>
|
|
<element ethereum:indexed="true" ethereum:type="address" name="_repayer"/>
|
|
<element ethereum:indexed="false" ethereum:type="uint256" name="_amountMinusFees"/>
|
|
<element ethereum:indexed="false" ethereum:type="uint256" name="_fees"/>
|
|
<element ethereum:indexed="false" ethereum:type="uint256" name="_borrowBalanceIncrease"/>
|
|
<element ethereum:indexed="false" ethereum:type="uint256" name="_timestamp"/>
|
|
</sequence>
|
|
</type>
|
|
</namedType>
|
|
</asnx:module>
|
|
|
|
<ts:label>
|
|
<ts:string xml:lang="en">DAI</ts:string>
|
|
</ts:label>
|
|
<ts:contract interface="erc20" name="DAI">
|
|
<ts:address network="1">0x6b175474e89094c44da98b954eedeac495271d0f</ts:address>
|
|
</ts:contract>
|
|
<ts:contract interface="erc20" name="aDAI">
|
|
<ts:address network="1">0xfC1E690f61EFd961294b3e1Ce3313fBD8aa4f85d</ts:address>
|
|
</ts:contract>
|
|
<ts:contract name="balance">
|
|
<ts:address network="1">0xb8c9fc923e67da6d7979bf2c290bd1df9c512bfa</ts:address>
|
|
</ts:contract>
|
|
<ts:contract name="LendingPoolProvider">
|
|
<ts:address network="1">0x24a42fD28C976A61Df5D00D0599C34c4f90748c8</ts:address>
|
|
</ts:contract>
|
|
<ts:contract name="AAVELendingPool">
|
|
<ts:address network="1">0x398eC7346DcD622eDc5ae82352F02bE94C62d119</ts:address>
|
|
</ts:contract>
|
|
<ts:contract name="AAVELendingPoolCore">
|
|
<ts:address network="1">0x3dfd23A6c5E8BbcFc9581d2E864a68feb6a076d3</ts:address>
|
|
</ts:contract>
|
|
<ts:contract name="PriceOracle">
|
|
<ts:address network="1">0x76B47460d7F7c5222cFb6b6A75615ab10895DDe4</ts:address>
|
|
</ts:contract>
|
|
<ts:contract name="AAVEGetters">
|
|
<ts:address network="1">0x38ba1173f498f7a89ac474edba1d587cc1ab021d</ts:address>
|
|
</ts:contract>
|
|
<ts:origins>
|
|
<ts:ethereum contract="DAI"/>
|
|
</ts:origins>
|
|
|
|
<ts:selection filter="allowance>0" name="enabled">
|
|
<ts:label>
|
|
<ts:string xml:lang="en">contract already enabled</ts:string>
|
|
</ts:label>
|
|
</ts:selection>
|
|
<ts:selection filter="allowance=0" name="notEnabled">
|
|
<ts:label>
|
|
<ts:string xml:lang="en">contract not enabled</ts:string>
|
|
</ts:label>
|
|
</ts:selection>
|
|
|
|
<ts:cards>
|
|
<ts:card type="action">
|
|
<ts:label>
|
|
<ts:string xml:lang="en">Convert to xDAI</ts:string>
|
|
</ts:label>
|
|
<ts:attribute name="amount">
|
|
<ts:type><ts:syntax>1.3.6.1.4.1.1466.115.121.1.36</ts:syntax></ts:type>
|
|
<ts:label>
|
|
<ts:string xml:lang="en">Amount in DAI</ts:string>
|
|
<ts:string xml:lang="zh">代幣金額</ts:string>
|
|
</ts:label>
|
|
<ts:origins>
|
|
<!-- e18 is a hard coded multiplier.
|
|
rationale for hardcoding: avoiding over-design -->
|
|
<ts:user-entry as="e18"/>
|
|
</ts:origins>
|
|
</ts:attribute>
|
|
<ts:transaction>
|
|
<ethereum:transaction contract="DAI" function="transfer">
|
|
<ts:data>
|
|
<!-- to convert erc20 DAI to native xDAI, transfer to this address -->
|
|
<ts:address>0x4aa42145Aa6Ebf72e164C9bBC74fbD3788045016</ts:address>
|
|
<ts:uint256 ref="amount"/>
|
|
</ts:data>
|
|
</ethereum:transaction>
|
|
</ts:transaction>
|
|
<ts:view xml:lang="en">
|
|
<xhtml:style type="text/css">h3 { color: #111; font-family: 'Open Sans', sans-serif; font-size: 20px; font-weight: 300; line-height: 32px; }
|
|
|
|
#inputBox {
|
|
text-align: center;
|
|
}
|
|
|
|
html,
|
|
body {
|
|
height: 100%;
|
|
}
|
|
html {
|
|
font-size: 14px;
|
|
}
|
|
body {
|
|
margin: 0px;
|
|
padding: 0px;
|
|
overflow-x: hidden;
|
|
min-width: 320px;
|
|
background: #FFFFFF;
|
|
font-family: 'Lato', 'Helvetica Neue', Arial, Helvetica, sans-serif;
|
|
font-size: 14px;
|
|
line-height: 1.4285em;
|
|
color: rgba(0, 0, 0, 0.87);
|
|
font-smoothing: antialiased;
|
|
}
|
|
.ui.container {
|
|
display: block;
|
|
max-width: 100% !important;
|
|
}
|
|
@media only screen and (max-width: 767px) {
|
|
.ui.container {
|
|
width: auto !important;
|
|
margin-left: 1em !important;
|
|
margin-right: 1em !important;
|
|
}
|
|
}
|
|
@media only screen and (min-width: 768px) and (max-width: 991px) {
|
|
.ui.container {
|
|
width: 723px;
|
|
margin-left: auto !important;
|
|
margin-right: auto !important;
|
|
}
|
|
}
|
|
@media only screen and (min-width: 992px) and (max-width: 1199px) {
|
|
.ui.container {
|
|
width: 933px;
|
|
margin-left: auto !important;
|
|
margin-right: auto !important;
|
|
}
|
|
}
|
|
@media only screen and (min-width: 1200px) {
|
|
.ui.container {
|
|
width: 1127px;
|
|
margin-left: auto !important;
|
|
margin-right: auto !important;
|
|
}
|
|
}
|
|
.ui.segment {
|
|
position: relative;
|
|
background: #FFFFFF;
|
|
-webkit-box-shadow: 0px 1px 2px 0 rgba(34, 36, 38, 0.15);
|
|
box-shadow: 0px 1px 2px 0 rgba(34, 36, 38, 0.15);
|
|
margin: 0.5rem 0em;
|
|
padding: 0.5em 0.5em;
|
|
border-radius: 0.28571429rem;
|
|
border: 1px solid rgba(34, 36, 38, 0.15);
|
|
text-align: center;
|
|
}
|
|
.ui.segment:first-child {
|
|
margin-top: 0em;
|
|
}
|
|
.ui.segment:last-child {
|
|
margin-bottom: 0em;
|
|
}
|
|
input {
|
|
position: relative;
|
|
font-weight: normal;
|
|
font-style: normal;
|
|
font-size: 12px;
|
|
display: -ms-inline-flexbox;
|
|
display: inline-flex;
|
|
color: rgba(0, 0, 0, 0.87);
|
|
padding: 9.5px 14px;
|
|
width: 300px;
|
|
border-color: #D8D8D8;
|
|
}
|
|
input[type=text]:focus {
|
|
border-color: #D8D8D8;
|
|
background: #FAFAFA;
|
|
color: rgba(0, 0, 0, 0.87);
|
|
-webkit-box-shadow: none;
|
|
box-shadow: none;
|
|
}
|
|
label {
|
|
font-size: 12px;
|
|
font-weight: 500;
|
|
margin-top: 6px;
|
|
}</xhtml:style>
|
|
<xhtml:script type="text/javascript">//
|
|
class Token {
|
|
constructor(tokenInstance) {
|
|
this.props = tokenInstance
|
|
}
|
|
|
|
render() {
|
|
return `
|
|
<div class="ui container">
|
|
<div class="ui segment">
|
|
<h3>Convert DAI to xDAI</h3>
|
|
<img src=""/>
|
|
<br>
|
|
<br>
|
|
<span>DAI Balance: <b>${this.props.balance / 1e+18}</b><br></span>
|
|
<input type="number" id="amount" placeholder="Amount to convert"/>
|
|
</div>
|
|
</div>`;
|
|
}
|
|
}
|
|
|
|
web3.tokens.dataChanged = (oldTokens, updatedTokens, tokenCardId) => {
|
|
const currentTokenInstance = updatedTokens.currentInstance;
|
|
document.getElementById(tokenCardId).innerHTML = new Token(currentTokenInstance).render();
|
|
};
|
|
//
|
|
</xhtml:script>
|
|
</ts:view>
|
|
</ts:card>
|
|
|
|
<ts:card exclude="enabled" type="action">
|
|
<ts:label>
|
|
<ts:string xml:lang="en">Enable Repayment</ts:string>
|
|
</ts:label>
|
|
<ts:transaction>
|
|
<ethereum:transaction as="bool" contract="DAI" function="approve">
|
|
<ts:data>
|
|
<ts:address>0xfC1E690f61EFd961294b3e1Ce3313fBD8aa4f85d</ts:address>
|
|
<ts:uint256>115792089237316195423570985008687907853269984665640564039457584007913129639935</ts:uint256>
|
|
</ts:data>
|
|
</ethereum:transaction>
|
|
</ts:transaction>
|
|
<ts:view xml:lang="en">
|
|
<xhtml:style type="text/css">.separator {
|
|
width: 100%;
|
|
height: 1px;
|
|
background-color: #e9e9e9;
|
|
margin-top: 7.5%;
|
|
}
|
|
|
|
.action {
|
|
height: 50px;
|
|
}
|
|
|
|
body{
|
|
margin-top: 0;
|
|
}
|
|
|
|
h1 {
|
|
margin-top: 0;
|
|
line-height: 2;
|
|
background-color: #fbfbfb;
|
|
border-bottom: thin solid rgb(235,235,235);
|
|
text-align: left;
|
|
font-variant: all-small-caps;
|
|
}
|
|
|
|
h2 {
|
|
float: left;
|
|
margin-top: 0;
|
|
margin-bottom: 0;
|
|
}
|
|
|
|
p.hint {
|
|
clear: left;
|
|
}
|
|
|
|
input {
|
|
float: right;
|
|
font-size: x-large;
|
|
border: none;
|
|
line-height: 40px;
|
|
text-align: right;
|
|
width: 5ex;
|
|
}
|
|
|
|
h2 img {
|
|
vertical-align: middle;
|
|
}
|
|
|
|
.action {
|
|
font-family: SourceSansPro, sans-serif;
|
|
}
|
|
|
|
.enable.action {
|
|
font-size: large;
|
|
text-align: center;
|
|
margin-left: 8%;
|
|
margin-right: 8%;
|
|
margin-top: 35%;
|
|
}
|
|
|
|
.enable.action img {
|
|
padding-bottom: 40px;
|
|
}
|
|
|
|
.titleAction {
|
|
width: 272px;
|
|
height: 24px;
|
|
font-size: 15px;
|
|
font-weight: 600;
|
|
font-stretch: normal;
|
|
font-style: normal;
|
|
line-height: 1.67;
|
|
letter-spacing: normal;
|
|
color: #727272;
|
|
}
|
|
|
|
.detailsTitle {
|
|
width: 246px;
|
|
height: 41px;
|
|
font-family: SourceSansPro-Semibold, sans-serif;
|
|
font-size: 24px;
|
|
font-weight: bold;
|
|
font-stretch: normal;
|
|
font-style: normal;
|
|
line-height: 1.71;
|
|
letter-spacing: normal;
|
|
color: black;
|
|
}
|
|
|
|
table {
|
|
margin-top: 1em;
|
|
width: 100%;
|
|
border-collapse: collapse;
|
|
}
|
|
|
|
table caption {
|
|
font-weight: bold;
|
|
font-size: x-large;
|
|
line-height: 2;
|
|
text-align: left;
|
|
}
|
|
|
|
table th {
|
|
font-weight: normal; /* Tomek likes to deemphasize field names */
|
|
text-align: left;
|
|
line-height: 3;
|
|
}
|
|
|
|
table td {
|
|
text-align: right;
|
|
font-weight: bold;
|
|
font-size: large;
|
|
line-height: 3;
|
|
}
|
|
|
|
table tr {
|
|
border-top: 1px solid #727272;
|
|
}
|
|
|
|
table tr:last-child {
|
|
border-bottom: 1px solid #727272;
|
|
}
|
|
</xhtml:style>
|
|
<xhtml:script type="text/javascript">//
|
|
class Token {
|
|
|
|
constructor(token, card) {
|
|
this.token = token;
|
|
this.card = card;
|
|
}
|
|
|
|
render() {
|
|
let message = "To Repay DAI from the Aave Protocol, you need to enable it first. It might take up to few minutes (depending on the gas price).";
|
|
return`
|
|
<div class="enable action">
|
|
<img src=""/>
|
|
<br/>${message}
|
|
</div>
|
|
`;
|
|
}
|
|
}
|
|
|
|
web3.tokens.dataChanged = (oldTokens, updated, tokenIdCard) => {
|
|
document.getElementById(tokenIdCard).innerHTML = new Token(updated.token, updated.card).render();
|
|
};
|
|
|
|
//
|
|
</xhtml:script>
|
|
</ts:view>
|
|
</ts:card>
|
|
|
|
<ts:card exclude="notEnabled" type="action">
|
|
<ts:label>
|
|
<ts:string xml:lang="en">Repay DAI to Aave</ts:string>
|
|
</ts:label>
|
|
<ts:attribute name="repayAmount">
|
|
<ts:type><ts:syntax>1.3.6.1.4.1.1466.115.121.1.36</ts:syntax></ts:type>
|
|
<ts:label>
|
|
<ts:string xml:lang="en">Amount to Repay</ts:string>
|
|
</ts:label>
|
|
<ts:origins>
|
|
<!-- e18 is a hard coded multiplier.
|
|
rationale for hardcoding: avoiding over-design -->
|
|
<ts:user-entry as="e18"/>
|
|
</ts:origins>
|
|
</ts:attribute>
|
|
<!-- default to user, unless they explicitly write someone else's address -->
|
|
<ts:attribute name="debtHolder">
|
|
<ts:type><ts:syntax>1.3.6.1.4.1.1466.115.121.1.36</ts:syntax></ts:type>
|
|
<ts:label>
|
|
<ts:string xml:lang="en">the address of whom's debt to repay</ts:string>
|
|
</ts:label>
|
|
<ts:origins>
|
|
<ts:user-entry as="address"/>
|
|
</ts:origins>
|
|
</ts:attribute>
|
|
<ts:transaction>
|
|
<ethereum:transaction as="uint" contract="LendingPoolProvider" function="repay">
|
|
<ts:data>
|
|
<ts:address>0x6b175474e89094c44da98b954eedeac495271d0f</ts:address>
|
|
<ts:uint256 ref="repayAmount"/>
|
|
<ts:address ref="debtHolder"/>
|
|
</ts:data>
|
|
</ethereum:transaction>
|
|
</ts:transaction>
|
|
<ts:view xmlns="http://www.w3.org/1999/xhtml" xml:lang="en">
|
|
<xhtml:style type="text/css">.separator {
|
|
width: 100%;
|
|
height: 1px;
|
|
background-color: #e9e9e9;
|
|
margin-top: 7.5%;
|
|
}
|
|
|
|
.action {
|
|
height: 50px;
|
|
}
|
|
|
|
body{
|
|
margin-top: 0;
|
|
}
|
|
|
|
h1 {
|
|
margin-top: 0;
|
|
line-height: 2;
|
|
background-color: #fbfbfb;
|
|
border-bottom: thin solid rgb(235,235,235);
|
|
text-align: left;
|
|
font-variant: all-small-caps;
|
|
}
|
|
|
|
h2 {
|
|
float: left;
|
|
margin-top: 0;
|
|
margin-bottom: 0;
|
|
}
|
|
|
|
p.hint {
|
|
clear: left;
|
|
}
|
|
|
|
input {
|
|
float: right;
|
|
font-size: x-large;
|
|
border: none;
|
|
line-height: 40px;
|
|
text-align: right;
|
|
width: 5ex;
|
|
}
|
|
|
|
h2 img {
|
|
vertical-align: middle;
|
|
}
|
|
|
|
.action {
|
|
font-family: SourceSansPro, sans-serif;
|
|
}
|
|
|
|
.enable.action {
|
|
font-size: large;
|
|
text-align: center;
|
|
margin-left: 8%;
|
|
margin-right: 8%;
|
|
margin-top: 35%;
|
|
}
|
|
|
|
.enable.action img {
|
|
padding-bottom: 40px;
|
|
}
|
|
|
|
.titleAction {
|
|
width: 272px;
|
|
height: 24px;
|
|
font-size: 15px;
|
|
font-weight: 600;
|
|
font-stretch: normal;
|
|
font-style: normal;
|
|
line-height: 1.67;
|
|
letter-spacing: normal;
|
|
color: #727272;
|
|
}
|
|
|
|
.detailsTitle {
|
|
width: 246px;
|
|
height: 41px;
|
|
font-family: SourceSansPro-Semibold, sans-serif;
|
|
font-size: 24px;
|
|
font-weight: bold;
|
|
font-stretch: normal;
|
|
font-style: normal;
|
|
line-height: 1.71;
|
|
letter-spacing: normal;
|
|
color: black;
|
|
}
|
|
|
|
table {
|
|
margin-top: 1em;
|
|
width: 100%;
|
|
border-collapse: collapse;
|
|
}
|
|
|
|
table caption {
|
|
font-weight: bold;
|
|
font-size: x-large;
|
|
line-height: 2;
|
|
text-align: left;
|
|
}
|
|
|
|
table th {
|
|
font-weight: normal; /* Tomek likes to deemphasize field names */
|
|
text-align: left;
|
|
line-height: 3;
|
|
}
|
|
|
|
table td {
|
|
text-align: right;
|
|
font-weight: bold;
|
|
font-size: large;
|
|
line-height: 3;
|
|
}
|
|
|
|
table tr {
|
|
border-top: 1px solid #727272;
|
|
}
|
|
|
|
table tr:last-child {
|
|
border-bottom: 1px solid #727272;
|
|
}
|
|
</xhtml:style>
|
|
<xhtml:script type="text/javascript">//
|
|
class Token {
|
|
|
|
constructor(token, card) {
|
|
this.token = token;
|
|
this.card = card;
|
|
}
|
|
|
|
render() {
|
|
const decimals18 = 1e+18;
|
|
let totalBorrows = this.token.borrowBalance / decimals18;
|
|
let interestAccrued = this.token.borrowInterestAccrued / decimals18;
|
|
let daiPriceInEth = this.token.assetPriceDAI / decimals18;
|
|
return`
|
|
<div class="repay action">
|
|
<h1>Repay</h1>
|
|
<h2><img src=""> DAI</h2>
|
|
<input id="redeemAmount" type="number" placeholder="0">
|
|
<p class="hint">Remaining to Repay: ${totalBorrows / daiPriceInEth} DAI</p>
|
|
<table>
|
|
<caption>Details</caption>
|
|
<tbody>
|
|
<tr>
|
|
<th>Total to repay </th>
|
|
<td>${totalBorrows / daiPriceInEth}</td>
|
|
</tr>
|
|
<tr>
|
|
<th>Borrowed</th>
|
|
<td>${(totalBorrows - interestAccrued) / daiPriceInEth} DAI</td>
|
|
</tr>
|
|
<tr>
|
|
<th>Interest to Repay</th>
|
|
<td>${interestAccrued}</td>
|
|
</tr>
|
|
</tbody>
|
|
</table>
|
|
</div>
|
|
`;
|
|
}
|
|
}
|
|
|
|
web3.tokens.dataChanged = (oldTokens, updated, tokenIdCard) => {
|
|
document.getElementById(tokenIdCard).innerHTML = new Token(updated.token, updated.card).render();
|
|
};
|
|
//
|
|
</xhtml:script>
|
|
</ts:view>
|
|
</ts:card>
|
|
|
|
<ts:card name="daiRepaid" type="activity">
|
|
<ts:origins>
|
|
<ethereum:event contract="aDAI" filter="_user=${ownerAddress}" type="Repay"/>
|
|
</ts:origins>
|
|
<ts:item-view xmlns="http://www.w3.org/1999/xhtml" xml:lang="en">
|
|
<xhtml:style type="text/css">.title {
|
|
font-family: SourceSansPro, sans-serif;
|
|
font-size: 17px;
|
|
margin-bottom: 3px;
|
|
margin-top: 2px;
|
|
/* Weiwu: you shouldn't need the following */
|
|
font-weight: normal;
|
|
font-stretch: normal;
|
|
font-style: normal;
|
|
letter-spacing: normal;
|
|
color: black;
|
|
}
|
|
|
|
.title .text-style {
|
|
font-weight: 600;
|
|
}
|
|
|
|
.subtitle {
|
|
font-family: SourceSansPro, sans-serif;
|
|
font-size: 12px;
|
|
font-weight: normal;
|
|
font-stretch: normal;
|
|
font-style: normal;
|
|
letter-spacing: normal;
|
|
color: #727272;
|
|
}
|
|
|
|
.container {
|
|
width: 100%;
|
|
/* use this instead of setting the line-height of subtitle */
|
|
margin-bottom: 5px;
|
|
/* this would break variable length activities - although the length of activity container is hard to get in the first place */
|
|
height: 100%;
|
|
padding-top: 1%;
|
|
}
|
|
|
|
.logo {
|
|
float: left;
|
|
width: 45px;
|
|
margin-right: 0.5em;
|
|
margin-left: 0.5em;
|
|
}
|
|
|
|
.info {
|
|
float: right;
|
|
text-align: right;
|
|
font-family: SourceSansPro-Semibold, sans-serif;
|
|
font-size: 17px;
|
|
font-weight: 600;
|
|
font-stretch: normal;
|
|
font-style: normal;
|
|
line-height: 1.71;
|
|
letter-spacing: normal;
|
|
color: black;
|
|
}
|
|
|
|
.time {
|
|
font-family: SourceSansPro-Regular, sans-serif;
|
|
font-size: 12px;
|
|
font-weight: normal;
|
|
font-stretch: normal;
|
|
font-style: normal;
|
|
line-height: 1.67;
|
|
letter-spacing: normal;
|
|
text-align: right;
|
|
color: #727272;
|
|
}
|
|
</xhtml:style>
|
|
<xhtml:script type="text/javascript">//
|
|
class Token {
|
|
|
|
constructor(token, card) {
|
|
this.token = token;
|
|
this.card = card;
|
|
this.time = this.formatTimeStamp(this.card.timestamp.date);
|
|
}
|
|
|
|
formatTimeStamp(time) {
|
|
let a = new Date(time);
|
|
let hours = a.getHours();
|
|
let minutes = a.getMinutes();
|
|
let ampm = hours >= 12 ? 'pm' : 'am';
|
|
hours = hours % 12;
|
|
hours = hours ? hours : 12; // the hour '0' should be '12'
|
|
minutes = minutes < 10 ? '0' + minutes : minutes;
|
|
return hours + ':' + minutes + ' ' + ampm;
|
|
}
|
|
|
|
render() {
|
|
return`
|
|
<div>
|
|
<div class="container">
|
|
<div class="logo">
|
|
<img src="">
|
|
</div>
|
|
<div class="info">
|
|
- ${(this.card._amountMinusFees + this.props._fees) / 1e+18} DAI<br/>
|
|
<div class="time">${this.time}</div>
|
|
</div>
|
|
<div class="title">
|
|
Repayment <strong>DAI</strong>
|
|
</div>
|
|
<div class="subtitle">
|
|
to Aave
|
|
</div>
|
|
</div>
|
|
</div>
|
|
`;
|
|
}
|
|
}
|
|
|
|
web3.tokens.dataChanged = (oldTokens, updated, tokenIdCard) => {
|
|
document.getElementById(tokenIdCard).innerHTML = new Token(updated.token, updated.card).render();
|
|
};
|
|
//
|
|
</xhtml:script>
|
|
</ts:item-view>
|
|
<ts:view xmlns="http://www.w3.org/1999/xhtml" xml:lang="en">
|
|
<xhtml:style type="text/css">.icons {
|
|
margin-top: 10%;
|
|
}
|
|
|
|
.date {
|
|
margin-top: 2%;
|
|
justify-content: center;
|
|
}
|
|
|
|
.logo {
|
|
width: 60px;
|
|
height: 60px;
|
|
object-fit: contain;
|
|
}
|
|
|
|
.sentSolid {
|
|
width: 34px;
|
|
height: 34px;
|
|
object-fit: contain;
|
|
}
|
|
|
|
.depositContainer {
|
|
width: 375px;
|
|
height: 34px;
|
|
font-family: SourceSansPro-Semibold, sans-serif;
|
|
font-size: 20px;
|
|
font-weight: 600;
|
|
font-stretch: normal;
|
|
font-style: normal;
|
|
line-height: 1.7;
|
|
letter-spacing: normal;
|
|
text-align: center;
|
|
color: black;
|
|
}
|
|
|
|
.headerRectangle {
|
|
width: 375px;
|
|
height: 150px;
|
|
background-color: #ffffff;
|
|
margin-top: 10%;
|
|
text-align: center;
|
|
}
|
|
|
|
.date {
|
|
font-family: SourceSansPro, sans-serif;
|
|
font-size: 12px;
|
|
font-weight: normal;
|
|
font-stretch: normal;
|
|
font-style: normal;
|
|
line-height: 1.67;
|
|
letter-spacing: normal;
|
|
text-align: center;
|
|
color: #727272;
|
|
}
|
|
|
|
.separator {
|
|
width: 100%;
|
|
height: 1px;
|
|
background-color: #e9e9e9;
|
|
margin-top: 7.5%;
|
|
}
|
|
|
|
.amountBox{
|
|
width: 375px;
|
|
height: 47px;
|
|
font-family: SourceSansPro-Regular, sans-serif;
|
|
font-size: 28px;
|
|
font-weight: normal;
|
|
font-stretch: normal;
|
|
font-style: normal;
|
|
line-height: 1.68;
|
|
letter-spacing: normal;
|
|
text-align: center;
|
|
color: black;
|
|
}
|
|
|
|
.midSection {
|
|
width: 375px;
|
|
height: 81px;
|
|
background-color: white;
|
|
}
|
|
</xhtml:style>
|
|
<xhtml:script type="text/javascript">//
|
|
class Token {
|
|
|
|
constructor(token, card) {
|
|
this.token = token;
|
|
this.card = card;
|
|
this.time = this.formatTimeStampTodayTime(this.card.timestamp.date) + " | " + this.formatTimeStamp(this.card.timestamp.date);
|
|
}
|
|
|
|
formatTimeStampTodayTime(time) {
|
|
let a = new Date(time);
|
|
let hours = a.getHours();
|
|
let minutes = a.getMinutes();
|
|
let ampm = hours >= 12 ? 'pm' : 'am';
|
|
hours = hours % 12;
|
|
hours = hours ? hours : 12; // the hour '0' should be '12'
|
|
minutes = minutes < 10 ? '0' + minutes : minutes;
|
|
return hours + ':' + minutes + ' ' + ampm;
|
|
}
|
|
|
|
formatTimeStamp(time) {
|
|
let a = new Date(time);
|
|
let months = ['Jan','Feb','Mar','Apr','May','Jun','Jul','Aug','Sep','Oct','Nov','Dec'];
|
|
let year = a.getFullYear();
|
|
let month = months[a.getMonth()];
|
|
let date = a.getDate();
|
|
return date + ' ' + month + ' ' + year;
|
|
}
|
|
|
|
render() {
|
|
return`
|
|
<div>
|
|
<div class="headerRectangle">
|
|
<div class="date">
|
|
<p>${this.time}</p>
|
|
</div>
|
|
|
|
<div class="icons">
|
|
<img class="logo" src="">
|
|
</div>
|
|
|
|
<div class="depositContainer">
|
|
<p>Repayment DAI</p>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="separator"></div>
|
|
|
|
<div class="amountBox">
|
|
<p>- ${this.card._amountMinusFees} DAI</p>
|
|
</div>
|
|
</div>
|
|
`;
|
|
}
|
|
}
|
|
|
|
web3.tokens.dataChanged = (oldTokens, updated, tokenIdCard) => {
|
|
document.getElementById(tokenIdCard).innerHTML = new Token(updated.token, updated.card).render();
|
|
};
|
|
//
|
|
</xhtml:script>
|
|
</ts:view>
|
|
</ts:card>
|
|
|
|
</ts:cards>
|
|
|
|
<ts:attribute name="assetPriceDAI">
|
|
<ts:type><ts:syntax>1.3.6.1.4.1.1466.115.121.1.36</ts:syntax></ts:type>
|
|
<ts:label>
|
|
<ts:string xml:lang="en">asset price</ts:string>
|
|
</ts:label>
|
|
<ts:origins>
|
|
<ethereum:call as="uint" contract="PriceOracle" function="getAssetPrice">
|
|
<ts:data>
|
|
<ts:address>0x6B175474E89094C44Da98b954EedeAC495271d0F</ts:address>
|
|
</ts:data>
|
|
</ethereum:call>
|
|
</ts:origins>
|
|
</ts:attribute>
|
|
|
|
<ts:attribute name="borrowRate">
|
|
<ts:type><ts:syntax>1.3.6.1.4.1.1466.115.121.1.36</ts:syntax></ts:type>
|
|
<ts:label>
|
|
<ts:string xml:lang="en">borrow rate on DAI debt</ts:string>
|
|
</ts:label>
|
|
<ts:origins>
|
|
<ethereum:call as="uint" contract="AAVEGetters" function="getBorrowRate">
|
|
<ts:data>
|
|
<ts:address>0x6B175474E89094C44Da98b954EedeAC495271d0F</ts:address>
|
|
<ts:address ref="ownerAddress"/>
|
|
</ts:data>
|
|
</ethereum:call>
|
|
</ts:origins>
|
|
</ts:attribute>
|
|
|
|
<ts:attribute name="borrowRateMode">
|
|
<ts:type><ts:syntax>1.3.6.1.4.1.1466.115.121.1.36</ts:syntax></ts:type>
|
|
<ts:label>
|
|
<ts:string xml:lang="en">borrow rate on DAI debt (1 is stable, 2 is variable)</ts:string>
|
|
</ts:label>
|
|
<ts:origins>
|
|
<ethereum:call as="uint" contract="AAVEGetters" function="getBorrowRateMode">
|
|
<ts:data>
|
|
<ts:address>0x6B175474E89094C44Da98b954EedeAC495271d0F</ts:address>
|
|
<ts:address ref="ownerAddress"/>
|
|
</ts:data>
|
|
</ethereum:call>
|
|
</ts:origins>
|
|
</ts:attribute>
|
|
|
|
<ts:attribute name="borrowBalance">
|
|
<ts:type><ts:syntax>1.3.6.1.4.1.1466.115.121.1.36</ts:syntax></ts:type>
|
|
<ts:label>
|
|
<ts:string xml:lang="en">Borrow balance compounded</ts:string>
|
|
</ts:label>
|
|
<ts:origins>
|
|
<ethereum:call as="uint" contract="AAVEGetters" function="getCompoundedBorrowBalance">
|
|
<ts:data>
|
|
<ts:address>0x6B175474E89094C44Da98b954EedeAC495271d0F</ts:address>
|
|
<ts:address ref="ownerAddress"/>
|
|
</ts:data>
|
|
</ethereum:call>
|
|
</ts:origins>
|
|
</ts:attribute>
|
|
|
|
<ts:attribute name="borrowInterestAccrued">
|
|
<ts:type><ts:syntax>1.3.6.1.4.1.1466.115.121.1.36</ts:syntax></ts:type>
|
|
<ts:label>
|
|
<ts:string xml:lang="en">Borrow balance compounded</ts:string>
|
|
</ts:label>
|
|
<ts:origins>
|
|
<ethereum:call as="uint" contract="AAVEGetters" function="getCompoundedBalanceMinusPrincipal">
|
|
<ts:data>
|
|
<ts:address>0x6B175474E89094C44Da98b954EedeAC495271d0F</ts:address>
|
|
<ts:address ref="ownerAddress"/>
|
|
</ts:data>
|
|
</ethereum:call>
|
|
</ts:origins>
|
|
</ts:attribute>
|
|
|
|
<ts:attribute name="balance">
|
|
<ts:type><ts:syntax>1.3.6.1.4.1.1466.115.121.1.36</ts:syntax></ts:type>
|
|
<ts:label>
|
|
<ts:string xml:lang="en">DAI-Balance</ts:string>
|
|
</ts:label>
|
|
<ts:origins>
|
|
<ethereum:call as="uint" contract="DAI" function="balanceOf">
|
|
<ts:data>
|
|
<ts:address ref="ownerAddress"/>
|
|
</ts:data>
|
|
</ethereum:call>
|
|
</ts:origins>
|
|
</ts:attribute>
|
|
|
|
<ts:attribute name="allowance">
|
|
<ts:type><ts:syntax>1.3.6.1.4.1.1466.115.121.1.36</ts:syntax></ts:type>
|
|
<ts:origins>
|
|
<ethereum:call as="uint" contract="DAI" function="allowance">
|
|
<ts:data>
|
|
<ts:address ref="ownerAddress"/>
|
|
<ts:address>0xfC1E690f61EFd961294b3e1Ce3313fBD8aa4f85d</ts:address>
|
|
</ts:data>
|
|
</ethereum:call>
|
|
</ts:origins>
|
|
</ts:attribute>
|
|
<ds:Signature xmlns:ds="http://www.w3.org/2000/09/xmldsig#">
|
|
<ds:SignedInfo>
|
|
<ds:CanonicalizationMethod Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#"/>
|
|
<ds:SignatureMethod Algorithm="http://www.w3.org/2001/04/xmldsig-more#rsa-sha256"/>
|
|
<ds:Reference URI="">
|
|
<ds:Transforms>
|
|
<ds:Transform Algorithm="http://www.w3.org/2000/09/xmldsig#enveloped-signature"/>
|
|
<ds:Transform Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#"/>
|
|
</ds:Transforms>
|
|
<ds:DigestMethod Algorithm="http://www.w3.org/2001/04/xmlenc#sha256"/>
|
|
<ds:DigestValue>ji3D967OnGwjGpwntAaaEivyut8AtlF6bawFvonyIdw=</ds:DigestValue>
|
|
</ds:Reference>
|
|
</ds:SignedInfo>
|
|
<ds:SignatureValue>
|
|
EnM1K86xNB6Zr49cPjfMke2QEfKWy8mkIb1SIvz03LYV200vik1hl71ptRta5DW8aouJfGq0OQ6o
|
|
PyIsrgumQGwYAO7yWvZh305WG3BpYVVJErXYEZVaZs6xAwJMrd08gaJ9NEUU5q+oxPUSeRZQfIjk
|
|
96raKxmWIORBvhtoo3JjYHOgw7BAwNOMNqbcNae4vS+KI+kOnShi5p15SbqdzGjWsOgmpwcl1Eq4
|
|
a6Tpv5ZsWBumnu9cccouSRuV4DHJZ/FZYGoiNFzmZx82q91aNGqa2dwRYa3nITcLt6PSgqZvrFVR
|
|
T/ORM3EzdPkXMk1xgXvxe9EGW9eFK2TBBBLkFg==
|
|
</ds:SignatureValue>
|
|
<ds:KeyInfo>
|
|
<ds:KeyName>AlphaWallet</ds:KeyName>
|
|
<ds:KeyValue>
|
|
<ds:RSAKeyValue>
|
|
<ds:Modulus>
|
|
tDHBH8jKLPEjpXsy/V9/XsXBYmc64SXx6IWG9CdJzm+iSrk3Od2ZZTS3DsR5+hp9hk6UwRyb1XKG
|
|
+TMrBODfxIIWricmnhxYMqiyvwDhecm4RU4YFteekBFAsuhEGCJBtmJSrle5G3iE/9FwvTfw/cxo
|
|
yAydv85OWc4UkxkfjzaXVqGGKCzSFhRm48HwG51/1nmC1mmPh070EMY4Km4N/ieJZ8egLjDAIZEI
|
|
EY5Cj7ig9PPnGf2pF21/z7vm3zQViXi6XJIBn1E5CTXzDW1y1BYe0QI+dxxY0o+97mwisZu7fVfB
|
|
/rJJm3g7Ye4/lITkZeRMP+OLYyG1pathItlrVQ==
|
|
</ds:Modulus>
|
|
<ds:Exponent>AQAB</ds:Exponent>
|
|
</ds:RSAKeyValue>
|
|
</ds:KeyValue>
|
|
<ds:X509Data>
|
|
<ds:X509Certificate>
|
|
MIIFUDCCBDigAwIBAgISAy095xt55U0Cc0++zYon7TT0MA0GCSqGSIb3DQEBCwUAMEoxCzAJBgNV
|
|
BAYTAlVTMRYwFAYDVQQKEw1MZXQncyBFbmNyeXB0MSMwIQYDVQQDExpMZXQncyBFbmNyeXB0IEF1
|
|
dGhvcml0eSBYMzAeFw0xOTA5MjQxMTA1MTdaFw0xOTEyMjMxMTA1MTdaMBMxETAPBgNVBAMMCCou
|
|
YXcuYXBwMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAtDHBH8jKLPEjpXsy/V9/XsXB
|
|
Ymc64SXx6IWG9CdJzm+iSrk3Od2ZZTS3DsR5+hp9hk6UwRyb1XKG+TMrBODfxIIWricmnhxYMqiy
|
|
vwDhecm4RU4YFteekBFAsuhEGCJBtmJSrle5G3iE/9FwvTfw/cxoyAydv85OWc4UkxkfjzaXVqGG
|
|
KCzSFhRm48HwG51/1nmC1mmPh070EMY4Km4N/ieJZ8egLjDAIZEIEY5Cj7ig9PPnGf2pF21/z7vm
|
|
3zQViXi6XJIBn1E5CTXzDW1y1BYe0QI+dxxY0o+97mwisZu7fVfB/rJJm3g7Ye4/lITkZeRMP+OL
|
|
YyG1pathItlrVQIDAQABo4ICZTCCAmEwDgYDVR0PAQH/BAQDAgWgMB0GA1UdJQQWMBQGCCsGAQUF
|
|
BwMBBggrBgEFBQcDAjAMBgNVHRMBAf8EAjAAMB0GA1UdDgQWBBRaKDKFkPztPgQee3418kofZddy
|
|
MTAfBgNVHSMEGDAWgBSoSmpjBH3duubRObemRWXv86jsoTBvBggrBgEFBQcBAQRjMGEwLgYIKwYB
|
|
BQUHMAGGImh0dHA6Ly9vY3NwLmludC14My5sZXRzZW5jcnlwdC5vcmcwLwYIKwYBBQUHMAKGI2h0
|
|
dHA6Ly9jZXJ0LmludC14My5sZXRzZW5jcnlwdC5vcmcvMBsGA1UdEQQUMBKCCCouYXcuYXBwggZh
|
|
dy5hcHAwTAYDVR0gBEUwQzAIBgZngQwBAgEwNwYLKwYBBAGC3xMBAQEwKDAmBggrBgEFBQcCARYa
|
|
aHR0cDovL2Nwcy5sZXRzZW5jcnlwdC5vcmcwggEEBgorBgEEAdZ5AgQCBIH1BIHyAPAAdwB0ftqD
|
|
Ma0zEJEhnM4lT0Jwwr/9XkIgCMY3NXnmEHvMVgAAAW1jKVxwAAAEAwBIMEYCIQCHuWOuAiqXC7Bn
|
|
nYLS4BDrOrVeObYC7zcQvru7Aqx5DAIhAP9ukUp9nnQBWgAgTdfK+GdhHxboIaxJz7456ws6myft
|
|
AHUAY/Lbzeg7zCzPC3KEJ1drM6SNYXePvXWmOLHHaFRL2I0AAAFtYyladwAABAMARjBEAiBaxydV
|
|
JMY5/hQyrjaMMonJgQBhEKBHvv4FbthX+lZfpAIga4sB0hDaoT4knZfVhVP/u/Uv47t6z1+TEWnL
|
|
/TresTwwDQYJKoZIhvcNAQELBQADggEBAGSPK0ivDprmvO72TVLZsuk/JDhCmXQcYe6cRGPiX7WL
|
|
c0B6wfLaxb0rrQdmGpTiTEHS6wEa6tOMEsfxutPWeOxlqFPU97QHhLrdBlf4IDfk8i1Em3rpPPQu
|
|
3M2u5nfeRXvsIxyB5vLQvuR/NwCQqA2bwkCrlLz7dr1iGem35DGI0ikIkdODTPI+RpwHK8b2iApA
|
|
w6XaVGA99eCJS2dHqeyHPAc1Yf+Klv+z0FyM38ZUfazRRIQ17LtolM1U/9Ynld20SXtCrIFbcmbo
|
|
w3piXuHLlDRcRxWqdL33yPoTEbPuLtS6vqDXefYP0RiYpQHHwJz4E6q5VCbK6LgILnIyX+M=
|
|
</ds:X509Certificate>
|
|
<ds:X509Certificate>
|
|
MIIEkjCCA3qgAwIBAgIQCgFBQgAAAVOFc2oLheynCDANBgkqhkiG9w0BAQsFADA/MSQwIgYDVQQK
|
|
ExtEaWdpdGFsIFNpZ25hdHVyZSBUcnVzdCBDby4xFzAVBgNVBAMTDkRTVCBSb290IENBIFgzMB4X
|
|
DTE2MDMxNzE2NDA0NloXDTIxMDMxNzE2NDA0NlowSjELMAkGA1UEBhMCVVMxFjAUBgNVBAoTDUxl
|
|
dCdzIEVuY3J5cHQxIzAhBgNVBAMTGkxldCdzIEVuY3J5cHQgQXV0aG9yaXR5IFgzMIIBIjANBgkq
|
|
hkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAnNMM8FrlLke3cl03g7NoYzDq1zUmGSXhvb418XCSL7e4
|
|
S0EFq6meNQhY7LEqxGiHC6PjdeTm86dicbp5gWAf15Gan/PQeGdxyGkOlZHP/uaZ6WA8SMx+yk13
|
|
EiSdRxta67nsHjcAHJyse6cF6s5K671B5TaYucv9bTyWaN8jKkKQDIZ0Z8h/pZq4UmEUEz9l6YKH
|
|
y9v6Dlb2honzhT+Xhq+w3Brvaw2VFn3EK6BlspkENnWAa6xK8xuQSXgvopZPKiAlKQTGdMDQMc2P
|
|
MTiVFrqoM7hD8bEfwzB/onkxEz0tNvjj/PIzark5McWvxI0NHWQWM6r6hCm21AvA2H3DkwIDAQAB
|
|
o4IBfTCCAXkwEgYDVR0TAQH/BAgwBgEB/wIBADAOBgNVHQ8BAf8EBAMCAYYwfwYIKwYBBQUHAQEE
|
|
czBxMDIGCCsGAQUFBzABhiZodHRwOi8vaXNyZy50cnVzdGlkLm9jc3AuaWRlbnRydXN0LmNvbTA7
|
|
BggrBgEFBQcwAoYvaHR0cDovL2FwcHMuaWRlbnRydXN0LmNvbS9yb290cy9kc3Ryb290Y2F4My5w
|
|
N2MwHwYDVR0jBBgwFoAUxKexpHsscfrb4UuQdf/EFWCFiRAwVAYDVR0gBE0wSzAIBgZngQwBAgEw
|
|
PwYLKwYBBAGC3xMBAQEwMDAuBggrBgEFBQcCARYiaHR0cDovL2Nwcy5yb290LXgxLmxldHNlbmNy
|
|
eXB0Lm9yZzA8BgNVHR8ENTAzMDGgL6AthitodHRwOi8vY3JsLmlkZW50cnVzdC5jb20vRFNUUk9P
|
|
VENBWDNDUkwuY3JsMB0GA1UdDgQWBBSoSmpjBH3duubRObemRWXv86jsoTANBgkqhkiG9w0BAQsF
|
|
AAOCAQEA3TPXEfNjWDjdGBX7CVW+dla5cEilaUcne8IkCJLxWh9KEik3JHRRHGJouM2VcGfl96S8
|
|
TihRzZvoroed6ti6WqEBmtzw3Wodatg+VyOeph4EYpr/1wXKtx8/wApIvJSwtmVi4MFU5aMqrSDE
|
|
6ea73Mj2tcMyo5jMd6jmeWUHK8so/joWUoHOUgwuX4Po1QYz+3dszkDqMp4fklxBwXRsW10KXzPM
|
|
TZ+sOPAveyxindmjkW8lGy+QsRlGPfZ+G6Z6h7mjem0Y+iWlkYcV4PIWL1iwBi8saCbGS5jN2p8M
|
|
+X+Q7UNKEkROb3N6KOqkqm57TH2H3eDJAkSnh6/DNFu0Qg==
|
|
</ds:X509Certificate>
|
|
</ds:X509Data>
|
|
</ds:KeyInfo>
|
|
</ds:Signature></ts:token>
|
|
|