An advanced Ethereum/EVM mobile wallet
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.
 
 
 
alpha-wallet-ios/TokenScriptFiles/aETH.tsml

1348 lines
90 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="ERC20-Events">
<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="Borrow">
<type>
<sequence>
<element ethereum:indexed="true" ethereum:type="address" name="_reserve"/>
<element ethereum:indexed="true" ethereum:type="address" name="_user"/>
<element ethereum:indexed="false" ethereum:type="uint256" name="_amount"/>
<element ethereum:indexed="false" ethereum:type="uint256" name="_borrowRateMode"/>
<element ethereum:indexed="false" ethereum:type="uint256" name="_borrowRate"/>
<element ethereum:indexed="false" ethereum:type="uint256" name="_originationFee"/>
<element ethereum:indexed="false" ethereum:type="uint256" name="_borrowBalanceIncrease"/>
<element ethereum:indexed="true" ethereum:type="uint16" name="_referral"/>
<element ethereum:indexed="false" ethereum:type="uint256" name="_timestamp"/>
</sequence>
</type>
</namedType>
<namedType name="Redeem">
<type>
<sequence>
<element ethereum:indexed="true" ethereum:type="address" name="_fromRedeemer"/>
<element ethereum:indexed="false" ethereum:type="uint256" name="_valueRedeemed"/>
<element ethereum:indexed="false" ethereum:type="uint256" name="_fromBalanceIncreaseRedeemed"/>
<element ethereum:indexed="false" ethereum:type="uint256" name="_fromIndexRedeemed"/>
</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">aETH</ts:string>
</ts:label>
<ts:contract name="balance">
<ts:address network="1">0xb8c9fc923e67da6d7979bf2c290bd1df9c512bfa</ts:address>
</ts:contract>
<ts:contract name="AAVEGetters">
<ts:address network="1">0x38ba1173f498f7a89ac474edba1d587cc1ab021d</ts:address>
</ts:contract>
<ts:contract name="PriceOracle">
<ts:address network="1">0x76B47460d7F7c5222cFb6b6A75615ab10895DDe4</ts:address>
</ts:contract>
<ts:contract interface="erc20" name="aETH">
<ts:address network="1">0x3a3a65aab0dd2a17e3f1947ba16138cd37d08c04</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:origins>
<ts:ethereum contract="aETH"/>
</ts:origins>
<ts:cards>
<ts:card type="action">
<ts:label>
<ts:string xml:lang="en">Withdraw ETH from Aave</ts:string>
</ts:label>
<ts:attribute name="redeemAmount">
<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 withdraw</ts:string>
</ts:label>
<ts:origins>
<ts:user-entry as="e8"/>
</ts:origins>
</ts:attribute>
<ts:transaction>
<ethereum:transaction as="uint" contract="aETH" function="redeem">
<ts:data>
<ts:uint256 ref="redeemAmount"/>
</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 totalBorrows = (this.token.totalBorrows / decimals18).toFixed(2);
let withdrawable = (this.token.availableBorrowsETH / decimals18);
//if you have other assets that add to your collateral, your withdrawable could be larger than your aETH balance
if(withdrawable &gt; aTokenBalance) {
withdrawable = aTokenBalance;
}
return `&lt;div class="withdraw action"&gt;
&lt;h1&gt;Withdraw&lt;/h1&gt;
&lt;h2&gt;&lt;img src=""&gt;&lt;/h2&gt;
&lt;input id="redeemAmount" type="number" placeholder="0"&gt;
&lt;p class="hint"&gt;Available to withdraw ${withdrawable.toFixed(3)} ETH&lt;/p&gt;
&lt;table&gt;
&lt;caption&gt;Deposits&lt;/caption&gt;
&lt;tbody&gt;
&lt;tr&gt;
&lt;th&gt;Total Deposited + Interest &lt;/th&gt;
&lt;td&gt;${aTokenBalance}&lt;/td&gt;
&lt;/tr&gt;
&lt;tr&gt;
&lt;th&gt;Borrowed&lt;/th&gt;
&lt;td&gt;${totalBorrows} ETH&lt;/td&gt;
&lt;/tr&gt;
&lt;tr&gt;
&lt;th&gt;Available to withdraw&lt;/th&gt;
&lt;td&gt;${withdrawable.toFixed(3)} ETH&lt;/td&gt;
&lt;/tr&gt;
&lt;/tbody&gt;
&lt;/table&gt;
&lt;/div&gt;`;
}
}
web3.tokens.dataChanged = (oldTokens, updated, tokenIdCard) =&gt; {
document.getElementById(tokenIdCard).innerHTML = new Token(updated.token, updated.card).render();
};
//
</xhtml:script>
</ts:view>
</ts:card>
<ts:card type="action">
<ts:label>
<ts:string xml:lang="en">Borrow DAI</ts:string>
</ts:label>
<ts:attribute name="borrowAmount">
<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 Borrow</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="borrow">
<ts:data>
<ts:address>0x6b175474e89094c44da98b954eedeac495271d0f</ts:address>
<ts:uint256 ref="borrowAmount"/>
<ts:uint256>2</ts:uint256> <!-- 1 is stable rate, 2 is variable rate -->
<ts:uint256>0</ts:uint256> <!-- referral code -->
</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 borrowAPY = ((this.token.userInterestRateBorrow / 1e+27) * 100).toFixed(2) + "%";
if(this.token.userInterestRateBorrow === 0) {
borrowAPY = "N/A";
}
let collateralValueInEth = (this.token.totalCollateral / decimals18).toFixed(2);
return `
&lt;div class="borrow action"&gt;
&lt;h1&gt;Borrow&lt;/h1&gt;
&lt;h2&gt;&lt;img src=""&gt;&lt;/h2&gt;
&lt;input id="borrowAmount" type="number" placeholder="0"&gt;
&lt;p class="hint"&gt;Available to borrow: ${((this.token.availableBorrowsETH / this.token.assetPriceDAI)).toFixed(2)} DAI&lt;/p&gt;
&lt;table&gt;
&lt;caption&gt;Details&lt;/caption&gt;
&lt;tbody&gt;
&lt;tr&gt;
&lt;th&gt;Variable Borrow APY &lt;/th&gt;
&lt;td&gt;${borrowAPY}&lt;/td&gt;
&lt;/tr&gt;
&lt;tr&gt;
&lt;th&gt;Maximum you can borrow&lt;/th&gt;
&lt;td&gt;${((this.token.availableBorrowsETH / this.token.assetPriceDAI)).toFixed(2)} DAI&lt;/td&gt;
&lt;/tr&gt;
&lt;tr&gt;
&lt;th&gt;You Already Borrowed&lt;/th&gt;
&lt;td&gt;${((this.token.totalBorrows / this.token.assetPriceDAI)).toFixed(2)} DAI&lt;/td&gt;
&lt;/tr&gt;
&lt;tr&gt;
&lt;th&gt;New Health Factor&lt;/th&gt;
&lt;td&gt;${(this.token.healthFactor / 1e+18).toFixed(2)}&lt;/td&gt;
&lt;/tr&gt;
&lt;tr&gt;
&lt;th&gt;Your collateral is worth&lt;/th&gt;
&lt;td&gt;${collateralValueInEth} ETH (${((this.token.totalCollateral / this.token.assetPriceDAI)).toFixed(2)} DAI)&lt;/td&gt;
&lt;/tr&gt;
&lt;/tbody&gt;
&lt;/table&gt;
&lt;/div&gt;`;
}
}
web3.tokens.dataChanged = (oldTokens, updated, tokenIdCard) =&gt; {
document.getElementById(tokenIdCard).innerHTML = new Token(updated.token, updated.card).render();
};
//
</xhtml:script>
</ts:view>
</ts:card>
<ts:card name="aETHRedeemed" type="activity">
<ts:origins>
<ethereum:event contract="aETH" filter="_fromRedeemer=${ownerAddress}" type="Redeem"/>
</ts:origins>
<ts:item-view xmlns="http://www.w3.org/1999/xhtml" xml:lang="en">
<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;
}
</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 &gt;= 12 ? 'pm' : 'am';
hours = hours % 12;
hours = hours ? hours : 12; // the hour '0' should be '12'
minutes = minutes &lt; 10 ? '0' + minutes : minutes;
return hours + ':' + minutes + ' ' + ampm;
}
render() {
return`
&lt;div&gt;
&lt;div class="container"&gt;
&lt;div class="logo"&gt;
&lt;img src=""&gt;
&lt;/div&gt;
&lt;div class="info"&gt;
- ${this.card._valueRedeemed / 1e+18} ETH&lt;br/&gt;
&lt;div class="time"&gt;${this.time}&lt;/div&gt;
&lt;/div&gt;
&lt;div class="title"&gt;
Withdrew &lt;strong&gt;ETH&lt;/strong&gt;
&lt;/div&gt;
&lt;div class="subtitle"&gt;
from Aave
&lt;/div&gt;
&lt;/div&gt;
&lt;/div&gt;
`;
}
}
web3.tokens.dataChanged = (oldTokens, updated, tokenIdCard) =&gt; {
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 &gt;= 12 ? 'pm' : 'am';
hours = hours % 12;
hours = hours ? hours : 12; // the hour '0' should be '12'
minutes = minutes &lt; 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`
&lt;div&gt;
&lt;div class="headerRectangle"&gt;
&lt;div class="date"&gt;
&lt;p&gt;${this.time}&lt;/p&gt;
&lt;/div&gt;
&lt;div class="icons"&gt;
&lt;img class="logo" src=""&gt;
&lt;/div&gt;
&lt;div class="depositContainer"&gt;
&lt;p&gt;Withdrew ETH&lt;/p&gt;
&lt;/div&gt;
&lt;/div&gt;
&lt;div class="separator"&gt;&lt;/div&gt;
&lt;div class="amountBox"&gt;
&lt;p&gt;- ${this.card._valueRedeemed} ETH&lt;/p&gt;
&lt;/div&gt;
&lt;/div&gt;
`;
}
}
web3.tokens.dataChanged = (oldTokens, updated, tokenIdCard) =&gt; {
document.getElementById(tokenIdCard).innerHTML = new Token(updated.token, updated.card).render();
};
//
</xhtml:script>
</ts:view>
</ts:card>
<ts:card name="aETHBorrowed" type="activity">
<ts:origins>
<ethereum:event contract="aETH" filter="_user=${ownerAddress}" type="Borrow"/>
</ts:origins>
<ts:item-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.formatTimeStamp(this.card.timestamp.date);
}
formatTimeStamp(time) {
let a = new Date(time);
let hours = a.getHours();
let minutes = a.getMinutes();
let ampm = hours &gt;= 12 ? 'pm' : 'am';
hours = hours % 12;
hours = hours ? hours : 12; // the hour '0' should be '12'
minutes = minutes &lt; 10 ? '0' + minutes : minutes;
return hours + ':' + minutes + ' ' + ampm;
}
render() {
return`
&lt;div&gt;
&lt;div class="container"&gt;
&lt;div class="logo"&gt;
&lt;img src=""&gt;
&lt;/div&gt;
&lt;div class="info"&gt;
+ ${this.card._amount / 1e+18} DAI&lt;br/&gt;
&lt;div class="time"&gt;${this.time}&lt;/div&gt;
&lt;/div&gt;
&lt;div class="title"&gt;
Borrowing &lt;strong&gt;DAI&lt;/strong&gt;
&lt;/div&gt;
&lt;div class="subtitle"&gt;
from Aave
&lt;/div&gt;
&lt;/div&gt;
&lt;/div&gt;
`;
}
}
web3.tokens.dataChanged = (oldTokens, updated, tokenIdCard) =&gt; {
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 &gt;= 12 ? 'pm' : 'am';
hours = hours % 12;
hours = hours ? hours : 12; // the hour '0' should be '12'
minutes = minutes &lt; 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`
&lt;div&gt;
&lt;div class="headerRectangle"&gt;
&lt;div class="date"&gt;
&lt;p&gt;${this.time}&lt;/p&gt;
&lt;/div&gt;
&lt;div class="icons"&gt;
&lt;img class="logo" src=""&gt;
&lt;/div&gt;
&lt;div class="depositContainer"&gt;
&lt;p&gt;Borrowing DAI&lt;/p&gt;
&lt;/div&gt;
&lt;/div&gt;
&lt;div class="separator"&gt;&lt;/div&gt;
&lt;div class="amountBox"&gt;
&lt;p&gt;+ ${this.card._amount} DAI&lt;/p&gt;
&lt;/div&gt;
&lt;/div&gt;
`;
}
}
web3.tokens.dataChanged = (oldTokens, updated, tokenIdCard) =&gt; {
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>
<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="aETH" 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="userInterestRateBorrow">
<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: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="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 borrowing</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>
<ts:attribute name="loanToValue">
<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">LTV</ts:string>
</ts:label>
<ts:origins>
<ethereum:call as="uint" contract="AAVEGetters" function="getLTV">
<ts:data>
<ts:address ref="ownerAddress"/>
</ts:data>
</ethereum:call>
</ts:origins>
</ts:attribute>
<ts:attribute name="availableBorrowsETH">
<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">borrowable</ts:string>
</ts:label>
<ts:origins>
<ethereum:call as="uint" contract="AAVEGetters" function="getAvailableBorrowsETH">
<ts:data>
<ts:address ref="ownerAddress"/>
</ts:data>
</ethereum:call>
</ts:origins>
</ts:attribute>
<ts:attribute name="healthFactor">
<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">health factor</ts:string>
</ts:label>
<ts:origins>
<ethereum:call as="uint" contract="AAVEGetters" function="getHealthFactor">
<ts:data>
<ts:address ref="ownerAddress"/>
</ts:data>
</ethereum:call>
</ts:origins>
</ts:attribute>
<ts:attribute name="totalCollateral">
<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">total collateral in ETH</ts:string>
</ts:label>
<ts:origins>
<ethereum:call as="uint" contract="AAVEGetters" function="getTotalCollateralETH">
<ts:data>
<ts:address ref="ownerAddress"/>
</ts:data>
</ethereum:call>
</ts:origins>
</ts:attribute>
<ts:attribute name="totalBorrows">
<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">total borrows in ETH</ts:string>
</ts:label>
<ts:origins>
<ethereum:call as="uint" contract="AAVEGetters" function="getTotalBorrowsETH">
<ts:data>
<ts:address ref="ownerAddress"/>
</ts:data>
</ethereum:call>
</ts:origins>
</ts:attribute>
<ts:attribute name="liquidationThreshold">
<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">liquidation threshold</ts:string>
</ts:label>
<ts:origins>
<ethereum:call as="uint" contract="AAVEGetters" function="getCurrentLiquidationThreshold">
<ts:data>
<ts:address ref="ownerAddress"/>
</ts:data>
</ethereum:call>
</ts:origins>
</ts:attribute>
<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>
<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>Mpu/KHXZdpCQM4wmFK3I2yl9pxBkSH3bXv59D+Gnpvw=</ds:DigestValue>
</ds:Reference>
</ds:SignedInfo>
<ds:SignatureValue>
kAVDItZy174O8SgRo6xq4BP66mzyaWQA6hB5w6L34pClOkrxe5TwBIdoyaIHW9bxxgzt9CczqoSF
gdeW9IDsC3nJ8UbJOnCUkcLnQXqOdCDmlwj6h4dhqtSbgPbfVmng1Anf3ll6j9b8hM1Deb0C9Iga
yj1A++dnjWuBx9Lfeh/aGoxknF8eOiA+GWbfxHwNUwVaahr6MHLhsTgQdv0emISrt0Hx3EeSD5lw
0zLP19ppj0rxTdWaV240mPBy3uZCBkdjIfL9gDK9hkVHVJUvEHNCU/mUlAxEAovUSXoHiySWWkjl
d+ph70jOnt018YbCz2g4ifid9cn2BzyZjcY0dg==
</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>