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.
1007 lines
84 KiB
1007 lines
84 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="aETH">
|
|
<namedType name="MintOnDeposit">
|
|
<type>
|
|
<sequence>
|
|
<element ethereum:indexed="true" ethereum:type="address" name="_fromMinter"/>
|
|
<element ethereum:indexed="false" ethereum:type="uint256" name="_valueMinted"/>
|
|
<element ethereum:indexed="false" ethereum:type="uint256" name="_fromBalanceIncreaseMinted"/>
|
|
<element ethereum:indexed="false" ethereum:type="uint256" name="_fromIndexMinted"/>
|
|
</sequence>
|
|
</type>
|
|
</namedType>
|
|
<namedType name="Transfer">
|
|
<type>
|
|
<sequence>
|
|
<element ethereum:indexed="true" ethereum:type="address" name="from"/>
|
|
<element ethereum:indexed="true" ethereum:type="address" name="to"/>
|
|
<element ethereum:indexed="false" ethereum:type="uint256" name="amount"/>
|
|
</sequence>
|
|
</type>
|
|
</namedType>
|
|
</asnx:module>
|
|
|
|
<ts:label>
|
|
<ts:string xml:lang="en">ETH</ts:string>
|
|
</ts:label>
|
|
|
|
<ts:contract name="balance">
|
|
<ts:address network="1">0xb8c9fc923e67da6d7979bf2c290bd1df9c512bfa</ts:address>
|
|
</ts:contract>
|
|
<ts:contract interface="erc20" name="aETH">
|
|
<ts:address network="1">0x3a3a65aab0dd2a17e3f1947ba16138cd37d08c04</ts:address>
|
|
</ts:contract>
|
|
<ts:contract interface="erc20" name="ETH">
|
|
<ts:address network="1">0x0000000000000000000000000000000000000000</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="AAVEGetters">
|
|
<ts:address network="1">0x38ba1173f498f7a89ac474edba1d587cc1ab021d</ts:address>
|
|
</ts:contract>
|
|
|
|
<ts:origins>
|
|
<ts:ethereum contract="ETH"/>
|
|
</ts:origins>
|
|
|
|
<ts:cards>
|
|
<ts:card name="depositeAAVE" type="action">
|
|
<ts:label>
|
|
<ts:string xml:lang="en">Deposit ETH to Aave</ts:string>
|
|
<ts:string xml:lang="zh">存款</ts:string>
|
|
</ts:label>
|
|
<ts:attribute name="mintAmount">
|
|
<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 Deposit</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 as="uint" contract="LendingPoolProvider" function="deposit">
|
|
<ts:data>
|
|
<ts:address>0xEeeeeEeeeEeEeeEeEeEeeEEEeeeeEeeeeeeeEEeE</ts:address>
|
|
<ts:uint256 ref="mintAmount"/>
|
|
<ts:uint256>1101</ts:uint256> <!-- placeholder referral -->
|
|
</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() {
|
|
const decimals18 = 1e+18;
|
|
let aTokenBalance = (this.token.aTokenBalance / decimals18).toFixed(2);
|
|
let tokenBalance = (this.token.tokenBalance / decimals18).toFixed(2);
|
|
let APR = ((this.token.interestRateSupply / 1e+27) * 100).toFixed(2);
|
|
let annualEarnings = (aTokenBalance * APR) / 100;
|
|
return`
|
|
<div class="deposit action">
|
|
<h1>Deposit</h1>
|
|
<h2><img src=""></h2>
|
|
<input id="mintAmount" type="number" placeholder="0">
|
|
<p class="hint">Available ${tokenBalance} ETH</p>
|
|
<table>
|
|
<caption>Details</caption>
|
|
<tbody>
|
|
<tr>
|
|
<th>Interest Rate (APY) </th>
|
|
<td>${APR}%</td>
|
|
</tr>
|
|
<tr>
|
|
<th>Annual Earnings</th>
|
|
<td>${annualEarnings.toFixed(5)} ETH</td>
|
|
</tr>
|
|
<tr>
|
|
<th>Supply Balance</th>
|
|
<td>${aTokenBalance} ETH</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="aETHMinted" type="activity">
|
|
<ts:origins>
|
|
<ethereum:event contract="aETH" filter="to=${ownerAddress}" type="Transfer"/>
|
|
</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.amount / 1e+18} aETH<br/>
|
|
<div class="time"><div class="time">${this.time}</div></div>
|
|
</div>
|
|
<div class="title">
|
|
Receive <strong>aETH</strong>
|
|
</div>
|
|
<div class="subtitle">
|
|
from 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>Received aETH</p>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="separator"></div>
|
|
|
|
<div class="amountBox">
|
|
<p>+ ${this.card.amount / 1e+18} aETH</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:card name="aETHReceived" type="activity">
|
|
<ts:origins>
|
|
<ethereum:event contract="aETH" filter="_fromMinter=${ownerAddress}" type="MintOnDeposit"/>
|
|
</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._valueMinted / 1e+18} ETH<br/>
|
|
<div class="time">${this.time}</div>
|
|
</div>
|
|
<div class="title">
|
|
Deposit <strong>aETH</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>Deposit ETH</p>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="separator"></div>
|
|
|
|
<div class="amountBox">
|
|
<p>- ${this.card._valueMinted / 1e+18} ETH</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>
|
|
|
|
<!-- your balance in ETH -->
|
|
<ts:attribute name="tokenBalance">
|
|
<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">Balance</ts:string>
|
|
<ts:string xml:lang="zh">餘額</ts:string>
|
|
</ts:label>
|
|
<ts:origins>
|
|
<!-- `balance` is a special contract deployed to display native ETH balance of the msg.sender-->
|
|
<ethereum:call as="uint" contract="balance" function="balanceOf">
|
|
<ts:data>
|
|
<ts:address ref="ownerAddress"/>
|
|
</ts:data>
|
|
</ethereum:call>
|
|
</ts:origins>
|
|
</ts:attribute>
|
|
|
|
<ts:attribute name="lendingPoolAddress">
|
|
<ts:type><ts:syntax>1.3.6.1.4.1.1466.115.121.1.15</ts:syntax></ts:type>
|
|
<ts:origins>
|
|
<ethereum:call as="address" contract="LendingPoolProvider" function="getLendingPool">
|
|
</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="ETH" function="allowance">
|
|
<ts:data>
|
|
<ts:address ref="ownerAddress"/>
|
|
<ts:address>0x3a3a65aab0dd2a17e3f1947ba16138cd37d08c04</ts:address>
|
|
</ts:data>
|
|
</ethereum:call>
|
|
</ts:origins>
|
|
</ts:attribute>
|
|
|
|
<ts:attribute name="aTokenBalance">
|
|
<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">Balance</ts:string>
|
|
<ts:string xml:lang="zh">餘額</ts:string>
|
|
</ts:label>
|
|
<ts:origins>
|
|
<ethereum:call as="uint" contract="aETH" function="balanceOf">
|
|
<ts:data>
|
|
<ts:address ref="ownerAddress"/>
|
|
</ts:data>
|
|
</ethereum:call>
|
|
</ts:origins>
|
|
</ts:attribute>
|
|
|
|
<ts:attribute name="stableInterestRateBorrow">
|
|
<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">Stable interest rate</ts:string>
|
|
<ts:string xml:lang="zh">固定借款利率</ts:string>
|
|
</ts:label>
|
|
<ts:origins>
|
|
<ethereum:call as="uint" contract="AAVELendingPool" function="getReserveCurrentStableBorrowRate">
|
|
<ts:data>
|
|
<ts:address>0xEeeeeEeeeEeEeeEeEeEeeEEEeeeeEeeeeeeeEEeE</ts:address>
|
|
</ts:data>
|
|
</ethereum:call>
|
|
</ts:origins>
|
|
</ts:attribute>
|
|
|
|
<ts:attribute name="variableInterestRateBorrow">
|
|
<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">Variable interest rate borrow</ts:string>
|
|
<ts:string xml:lang="zh">动态借款利率</ts:string>
|
|
</ts:label>
|
|
<ts:origins>
|
|
<ethereum:call as="uint" contract="AAVELendingPool" function="getReserveCurrentVariableBorrowRate">
|
|
<ts:data>
|
|
<ts:address>0xEeeeeEeeeEeEeeEeEeEeeEEEeeeeEeeeeeeeEEeE</ts:address>
|
|
</ts:data>
|
|
</ethereum:call>
|
|
</ts:origins>
|
|
</ts:attribute>
|
|
|
|
<ts:attribute name="interestRateSupply">
|
|
<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">interest rate supply</ts:string>
|
|
</ts:label>
|
|
<ts:origins>
|
|
<ethereum:call as="uint" contract="AAVEGetters" function="getLiquidityRate">
|
|
<ts:data>
|
|
<ts:address>0xEeeeeEeeeEeEeeEeEeEeeEEEeeeeEeeeeeeeEEeE</ts:address>
|
|
<ts:address ref="ownerAddress"/>
|
|
</ts:data>
|
|
</ethereum:call>
|
|
</ts:origins>
|
|
</ts:attribute>
|
|
|
|
<ts:attribute name="aTokenPrincipleBalance">
|
|
<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">Principal Balance</ts:string>
|
|
<ts:string xml:lang="zh">本金</ts:string>
|
|
</ts:label>
|
|
<ts:origins>
|
|
<ethereum:call as="uint" contract="aETH" function="principalBalanceOf">
|
|
<ts:data>
|
|
<ts:address ref="ownerAddress"/>
|
|
</ts:data>
|
|
</ethereum:call>
|
|
</ts:origins>
|
|
</ts:attribute>
|
|
|
|
<ts:attribute name="enabledForBorrowing">
|
|
<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">Enabled for Collateralization</ts:string>
|
|
<ts:string xml:lang="zh">已授权用于抵押贷款</ts:string>
|
|
</ts:label>
|
|
<ts:origins>
|
|
<ethereum:call as="bool" contract="LendingPoolProvider" function="isUserUseReserveAsCollateralEnabled">
|
|
<ts:data>
|
|
<ts:address>0xEeeeeEeeeEeEeeEeEeEeeEEEeeeeEeeeeeeeEEeE</ts:address>
|
|
<ts:address ref="ownerAddress"/>
|
|
</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>uM4wbgeb5jaeOVuP3Du7asH5kC078uedzNH/gOGQ/Yw=</ds:DigestValue>
|
|
</ds:Reference>
|
|
</ds:SignedInfo>
|
|
<ds:SignatureValue>
|
|
cVaX8zZ6C/ynWJ3V8Y2eFttLYPEb0uJJkunwJ5y1zNA3lTgdxarc9rDYP/GDs9KIAlPinyQY1M7U
|
|
HoNP0YDqA7+8XX1vAlZcfrOAjcaVL1a9mZZyTCmRHdWUilk6vqK6LhVzJyURS1En7Pu3lrPNzEMr
|
|
TBxuMwh7S7UfXZ4q87WKC979UkcNM/dFdA7/BmA3y0BGu95p8OP07oaithFmiBmN7f3hQRjl/jom
|
|
B4m9UmGtSwyFegMoHR1B1delklaeJa+5HIYswEaK9SNDT4aorA2sBT+Jv6cPC+WGx/LFR8Yj6m0W
|
|
1RodyvpofZrnB25pnLf30GwhVLUFy5/nH/e37w==
|
|
</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>
|
|
|