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/ERC721-TokenScript.tsml

346 lines
46 KiB

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE token [
<!ENTITY style SYSTEM "layouts/shared.css">
<!ENTITY item-view-sent.en SYSTEM "layouts/item-view-sent.en.js">
<!ENTITY item-view-received.en SYSTEM "layouts/item-view-sent.en.js">
<!ENTITY item-view-approvalObtained.en SYSTEM "layouts/item-view-approvalObtained.en.js">
<!ENTITY item-view-ownerApproved.en SYSTEM "layouts/item-view-ownerApproved.en.js">
<!ENTITY sent.en SYSTEM "layouts/sent.en.js">
<!ENTITY received.en SYSTEM "layouts/received.en.js">
<!ENTITY receivedApproval.en SYSTEM "layouts/receivedApproval.en.js">
<!ENTITY gaveApproval.en SYSTEM "layouts/gaveApproval.en.js">
]>
<ts:token xmlns:ts="http://tokenscript.org/2020/06/tokenscript"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:asnx="urn:ietf:params:xml:ns:asnx"
xmlns:ethereum="urn:ethereum:constantinople"
xsi:schemaLocation="http://tokenscript.org/2020/06/tokenscript http://tokenscript.org/2020/06/tokenscript.xsd"
custodian="false"
>
<asnx:module name="ERC721-Events">
<namedType name="Approval">
<type>
<sequence>
<element name="owner" ethereum:type="address" ethereum:indexed="true"/>
<element name="approved" ethereum:type="address" ethereum:indexed="true"/>
<element name="tokenId" ethereum:type="uint256" ethereum:indexed="false"/>
</sequence>
</type>
</namedType>
<namedType name="Transfer">
<type>
<sequence>
<element name="from" ethereum:type="address" ethereum:indexed="true"/>
<element name="to" ethereum:type="address" ethereum:indexed="true"/>
<element name="tokenId" ethereum:type="uint256" ethereum:indexed="false"/>
</sequence>
</type>
</namedType>
</asnx:module>
<ts:cards>
<ts:card type="activity" name="sent">
<ts:origins>
<!-- this gives you card attributes from, to, tokenID, which is different than the
token's attributes -->
<ethereum:event type="Transfer" filter="from=${ownerAddress}"/>
</ts:origins>
<ts:item-view xml:lang="en" xmlns="http://www.w3.org/1999/xhtml">
<style type="text/css">&style;</style>
<script type="text/javascript">
class Token {
constructor(tokenInstance) {
this.props = tokenInstance;
this.setConfirm();
}
setConfirm() {
window.onConfirm = function() {
window.close();
}
}
render() {
let message = "Sample about page for your token, fill me up!";
return`
&lt;div class="ui container"&gt;
&lt;div class="ui segment"&gt;
&lt;span&gt;&lt;bold&gt;&lt;h3&gt;Sent ${this.props.symbol} tokenId: ${this.props.tokenId}&lt;/h3&gt;&lt;/bold&gt;&lt;/span&gt;
&lt;/div&gt;
&lt;/div&gt;
`;
}
}
web3.tokens.dataChanged = (oldTokens, updatedTokens, tokenIdCard) =&gt; {
const currentTokenInstance = web3.tokens.data.currentInstance;
document.getElementById(tokenIdCard).innerHTML = new Token(currentTokenInstance).render();
};
</script>
</ts:item-view>
<ts:view xml:lang="en" xmlns="http://www.w3.org/1999/xhtml">
<style type="text/css">&style;</style>
<script type="text/javascript">
class Token {
constructor(tokenInstance) {
this.props = tokenInstance;
}
render() {
let message = `Sent ${this.props.symbol}`;
return`
&lt;div class="ui container"&gt;
&lt;div class="ui segment"&gt;
&lt;span&gt;&lt;bold&gt;&lt;h3&gt;${message}&lt;/h3&gt;&lt;/bold&gt;&lt;/span&gt;
&lt;p&gt;Sent tokenId: ${this.props.tokenId} ${this.props.symbol}&lt;/p&gt;
&lt;/div&gt;
&lt;/div&gt;
`;
}
}
web3.tokens.dataChanged = (oldTokens, updatedTokens, tokenIdCard) =&gt; {
const currentTokenInstance = web3.tokens.data.currentInstance;
document.getElementById(tokenIdCard).innerHTML = new Token(currentTokenInstance).render();
};
</script>
</ts:view>
</ts:card>
<ts:card type="activity" name="received">
<ts:origins>
<!-- this gives you card attributes from, to, tokenId, which is different than the
token's attributes which also have tokenId -->
<ethereum:event type="Transfer" filter="to=${ownerAddress}"/>
</ts:origins>
<ts:item-view xml:lang="en" xmlns="http://www.w3.org/1999/xhtml">
<style type="text/css">&style;</style>
<script type="text/javascript">
class Token {
constructor(tokenInstance) {
this.props = tokenInstance;
this.setConfirm();
}
setConfirm() {
window.onConfirm = function() {
window.close();
}
}
render() {
let message = "Sample about page for your token, fill me up!";
return`
&lt;div class="ui container"&gt;
&lt;div class="ui segment"&gt;
&lt;span&gt;&lt;bold&gt;&lt;h3&gt;Received ${this.props.symbol} tokenId: ${this.props.tokenId}&lt;/h3&gt;&lt;/bold&gt;&lt;/span&gt;
&lt;/div&gt;
&lt;/div&gt;
`;
}
}
web3.tokens.dataChanged = (oldTokens, updatedTokens, tokenIdCard) =&gt; {
const currentTokenInstance = web3.tokens.data.currentInstance;
document.getElementById(tokenIdCard).innerHTML = new Token(currentTokenInstance).render();
};
</script>
</ts:item-view>
<ts:view xml:lang="en" xmlns="http://www.w3.org/1999/xhtml">
<style type="text/css">&style;</style>
<script type="text/javascript">
class Token {
constructor(tokenInstance) {
this.props = tokenInstance;
}
render() {
let message = `Received ${this.props.symbol}`;
return`
&lt;div class="ui container"&gt;
&lt;div class="ui segment"&gt;
&lt;span&gt;&lt;bold&gt;&lt;h3&gt;${message}&lt;/h3&gt;&lt;/bold&gt;&lt;/span&gt;
&lt;p&gt;Received tokenId: ${this.props.tokenId} ${this.props.symbol}&lt;/p&gt;
&lt;/div&gt;
&lt;/div&gt;
`;
}
}
web3.tokens.dataChanged = (oldTokens, updatedTokens, tokenIdCard) =&gt; {
const currentTokenInstance = web3.tokens.data.currentInstance;
document.getElementById(tokenIdCard).innerHTML = new Token(currentTokenInstance).render();
};
</script>
</ts:view>
</ts:card>
<ts:card type="activity" name="ownerApproved">
<ts:origins>
<ethereum:event type="Approval" filter="owner=${ownerAddress}"/>
</ts:origins>
<ts:item-view xml:lang="en" xmlns="http://www.w3.org/1999/xhtml">
<style type="text/css">&style;</style>
<script type="text/javascript">
class Token {
constructor(tokenInstance) {
this.props = tokenInstance;
this.setConfirm();
}
setConfirm() {
window.onConfirm = function() {
window.close();
}
}
render() {
return`
&lt;div class="ui container"&gt;
&lt;div class="ui segment"&gt;
&lt;span&gt;&lt;bold&gt;&lt;h3&gt;Gave approval to move tokenId: ${this.props.tokenId} ${this.props.symbol} to ${this.props.to}&lt;/h3&gt;&lt;/bold&gt;&lt;/span&gt;
&lt;/div&gt;
&lt;/div&gt;
`;
}
}
web3.tokens.dataChanged = (oldTokens, updatedTokens, tokenIdCard) =&gt; {
const currentTokenInstance = web3.tokens.data.currentInstance;
document.getElementById(tokenIdCard).innerHTML = new Token(currentTokenInstance).render();
};
</script>
</ts:item-view>
<ts:view xml:lang="en" xmlns="http://www.w3.org/1999/xhtml">
<style type="text/css">&style;</style>
<script type="text/javascript">
class Token {
constructor(tokenInstance) {
this.props = tokenInstance;
}
render() {
let message = `Given approval for ${this.props.symbol}`;
return`
&lt;div class="ui container"&gt;
&lt;div class="ui segment"&gt;
&lt;img src="
&lt;span&gt;&lt;bold&gt;&lt;h3&gt;${message}&lt;/h3&gt;&lt;/bold&gt;&lt;/span&gt;
&lt;p&gt;You have approved ${this.props.to} to move tokenId: ${this.props.tokenId} ${this.props.symbol}&lt;/p&gt;
&lt;/div&gt;
&lt;/div&gt;
`;
}
}
web3.tokens.dataChanged = (oldTokens, updatedTokens, tokenIdCard) =&gt; {
const currentTokenInstance = web3.tokens.data.currentInstance;
document.getElementById(tokenIdCard).innerHTML = new Token(currentTokenInstance).render();
};
</script>
</ts:view>
</ts:card>
<ts:card type="activity" name="approvalObtained">
<ts:origins>
<ethereum:event type="Approval" filter="approved=${ownerAddress}"/>
</ts:origins>
<ts:item-view xml:lang="en" xmlns="http://www.w3.org/1999/xhtml">
<style type="text/css">&style;</style>
<script type="text/javascript">
class Token {
constructor(tokenInstance) {
this.props = tokenInstance;
this.setConfirm();
}
setConfirm() {
window.onConfirm = function() {
window.close();
}
}
render() {
return`
&lt;div class="ui container"&gt;
&lt;div class="ui segment"&gt;
&lt;span&gt;&lt;bold&gt;&lt;h3&gt;Approved to move tokenId: ${this.props.tokenId} ${this.props.symbol} from ${this.props.from}&lt;/h3&gt;&lt;/bold&gt;&lt;/span&gt;
&lt;/div&gt;
&lt;/div&gt;
`;
}
}
web3.tokens.dataChanged = (oldTokens, updatedTokens, tokenIdCard) =&gt; {
const currentTokenInstance = web3.tokens.data.currentInstance;
document.getElementById(tokenIdCard).innerHTML = new Token(currentTokenInstance).render();
};
</script>
</ts:item-view>
<ts:view xml:lang="en" xmlns="http://www.w3.org/1999/xhtml">
<style type="text/css">&style;</style>
<script type="text/javascript">
class Token {
constructor(tokenInstance) {
this.props = tokenInstance;
}
render() {
let message = `Received approval for ${this.props.symbol}`;
return`
&lt;div class="ui container"&gt;
&lt;div class="ui segment"&gt;
&lt;img src="
&lt;span&gt;&lt;bold&gt;&lt;h3&gt;${message}&lt;/h3&gt;&lt;/bold&gt;&lt;/span&gt;
&lt;p&gt;Approved to move tokenId: ${this.props.tokenId} ${this.props.symbol} from ${this.props.from}&lt;/p&gt;
&lt;/div&gt;
&lt;/div&gt;
`;
}
}
web3.tokens.dataChanged = (oldTokens, updatedTokens, tokenIdCard) =&gt; {
const currentTokenInstance = web3.tokens.data.currentInstance;
document.getElementById(tokenIdCard).innerHTML = new Token(currentTokenInstance).render();
};
</script>
</ts:view>
</ts:card>
</ts:cards>
<ts:attribute name="name">
<ts:type>
<ts:syntax>1.3.6.1.4.1.1466.115.121.1.26</ts:syntax>
</ts:type>
<ts:label>
<ts:string xml:lang="en">name</ts:string>
</ts:label>
<ts:origins>
<ethereum:call function="name" as="utf8"/>
</ts:origins>
</ts:attribute>
<ts:attribute name="symbol">
<ts:type>
<ts:syntax>1.3.6.1.4.1.1466.115.121.1.26</ts:syntax>
</ts:type>
<ts:label>
<ts:string xml:lang="en">symbol</ts:string>
</ts:label>
<ts:origins>
<ethereum:call function="symbol" as="utf8"/>
</ts:origins>
</ts:attribute>
</ts:token>