147 lines
6.9 KiB
QML
147 lines
6.9 KiB
QML
import QtQuick 2.15
|
|
import utils 1.0
|
|
|
|
QtObject {
|
|
id: root
|
|
|
|
property var communityTokensModuleInst: communityTokensModule ?? null
|
|
|
|
// Network selection properties:
|
|
property var layer1Networks: networksModule.layer1
|
|
property var layer2Networks: networksModule.layer2
|
|
property var enabledNetworks: networksModule.enabled
|
|
property var allNetworks: networksModule.all
|
|
|
|
signal deployFeeUpdated(var ethCurrency, var fiatCurrency, int error)
|
|
signal selfDestructFeeUpdated(var ethCurrency, var fiatCurrency, int error)
|
|
signal airdropFeeUpdated(var airdropFees)
|
|
signal burnFeeUpdated(var ethCurrency, var fiatCurrency, int error)
|
|
|
|
signal deploymentStateChanged(string communityId, int status, string url)
|
|
signal ownerTokenDeploymentStateChanged(string communityId, int status, string url)
|
|
signal remoteDestructStateChanged(string communityId, string tokenName, int status, string url)
|
|
signal burnStateChanged(string communityId, string tokenName, int status, string url)
|
|
signal airdropStateChanged(string communityId, string tokenName, string chainName, int status, string url)
|
|
signal ownerTokenDeploymentStarted(string communityId, string url)
|
|
|
|
// Minting tokens:
|
|
function deployCollectible(communityId, collectibleItem)
|
|
{
|
|
if (collectibleItem.key !== "")
|
|
deleteToken(communityId, collectibleItem.key)
|
|
|
|
const jsonArtworkFile = Utils.getImageAndCropInfoJson(collectibleItem.artworkSource, collectibleItem.artworkCropRect)
|
|
communityTokensModuleInst.deployCollectible(communityId, collectibleItem.accountAddress, collectibleItem.name,
|
|
collectibleItem.symbol, collectibleItem.description, collectibleItem.supply,
|
|
collectibleItem.infiniteSupply, collectibleItem.transferable, collectibleItem.remotelyDestruct,
|
|
collectibleItem.chainId, jsonArtworkFile)
|
|
}
|
|
|
|
function deployAsset(communityId, assetItem)
|
|
{
|
|
if (assetItem.key !== "")
|
|
deleteToken(communityId, assetItem.key)
|
|
|
|
const jsonArtworkFile = Utils.getImageAndCropInfoJson(assetItem.artworkSource, assetItem.artworkCropRect)
|
|
communityTokensModuleInst.deployAssets(communityId, assetItem.accountAddress, assetItem.name,
|
|
assetItem.symbol, assetItem.description, assetItem.supply,
|
|
assetItem.infiniteSupply, assetItem.decimals, assetItem.chainId, jsonArtworkFile)
|
|
}
|
|
|
|
function deployOwnerToken(communityId, ownerToken, tMasterToken)
|
|
{
|
|
const jsonArtworkFile = Utils.getImageAndCropInfoJson(ownerToken.artworkSource, ownerToken.artworkCropRect)
|
|
communityTokensModuleInst.deployOwnerToken(communityId, ownerToken.accountAddress, ownerToken.name, ownerToken.symbol, ownerToken.description,
|
|
tMasterToken.name, tMasterToken.symbol, tMasterToken.description, ownerToken.chainId, jsonArtworkFile)
|
|
}
|
|
|
|
function deleteToken(communityId, contractUniqueKey) {
|
|
let parts = contractUniqueKey.split("_");
|
|
communityTokensModuleInst.removeCommunityToken(communityId, parts[0], parts[1])
|
|
}
|
|
|
|
readonly property Connections connections: Connections {
|
|
target: communityTokensModuleInst
|
|
|
|
function onDeployFeeUpdated(ethCurrency, fiatCurrency, errorCode) {
|
|
root.deployFeeUpdated(ethCurrency, fiatCurrency, errorCode)
|
|
}
|
|
|
|
function onSelfDestructFeeUpdated(ethCurrency, fiatCurrency, errorCode) {
|
|
root.selfDestructFeeUpdated(ethCurrency, fiatCurrency, errorCode)
|
|
}
|
|
|
|
function onAirdropFeesUpdated(jsonFees) {
|
|
root.airdropFeeUpdated(JSON.parse(jsonFees))
|
|
}
|
|
|
|
function onDeploymentStateChanged(communityId, status, url) {
|
|
root.deploymentStateChanged(communityId, status, url)
|
|
}
|
|
|
|
function onOwnerTokenDeploymentStateChanged(communityId, status, url) {
|
|
root.ownerTokenDeploymentStateChanged(communityId, status, url)
|
|
}
|
|
|
|
function onOwnerTokenDeploymentStarted(communityId, url) {
|
|
root.ownerTokenDeploymentStarted(communityId, url)
|
|
}
|
|
|
|
function onRemoteDestructStateChanged(communityId, tokenName, status, url) {
|
|
root.remoteDestructStateChanged(communityId, tokenName, status, url)
|
|
}
|
|
|
|
function onAirdropStateChanged(communityId, tokenName, chainName, status, url) {
|
|
root.airdropStateChanged(communityId, tokenName, chainName, status, url)
|
|
}
|
|
|
|
function onBurnStateChanged(communityId, tokenName, status, url) {
|
|
root.burnStateChanged(communityId, tokenName, status, url)
|
|
}
|
|
|
|
function onBurnFeeUpdated(ethCurrency, fiatCurrency, errorCode) {
|
|
root.burnFeeUpdated(ethCurrency, fiatCurrency, errorCode)
|
|
}
|
|
}
|
|
|
|
function computeDeployFee(chainId, accountAddress, tokenType, isOwnerDeployment) {
|
|
communityTokensModuleInst.computeDeployFee(chainId, accountAddress, tokenType, isOwnerDeployment)
|
|
}
|
|
|
|
function computeSelfDestructFee(selfDestructTokensList, tokenKey, accountAddress) {
|
|
//TODO uncomment accountAddress when supported in backend
|
|
communityTokensModuleInst.computeSelfDestructFee(JSON.stringify(selfDestructTokensList), tokenKey, /*accountAddress*/)
|
|
}
|
|
|
|
function remoteSelfDestructCollectibles(communityId, selfDestructTokensList, tokenKey, accountAddress) {
|
|
//TODO uncomment accountAddress when supported in backend
|
|
communityTokensModuleInst.selfDestructCollectibles(communityId, JSON.stringify(selfDestructTokensList), tokenKey, /*accountAddress*/)
|
|
}
|
|
|
|
// Burn:
|
|
function computeBurnFee(tokenKey, amount, accountAddress) {
|
|
console.assert(typeof amount === "string")
|
|
// TODO: Backend. It should include the account address in the calculation.
|
|
communityTokensModuleInst.computeBurnFee(tokenKey, amount/*, accountAddress*/)
|
|
}
|
|
|
|
function burnToken(communityId, tokenKey, burnAmount, accountAddress) {
|
|
console.assert(typeof burnAmount === "string")
|
|
// TODO: Backend. It should include the account address in the burn action.
|
|
communityTokensModuleInst.burnTokens(communityId, tokenKey, burnAmount/*, accountAddress*/)
|
|
}
|
|
|
|
// Airdrop tokens:
|
|
function airdrop(communityId, airdropTokens, addresses, feeAccountAddress) {
|
|
// TODO: Take `feeAccountAddress` into account for the airdrop
|
|
communityTokensModuleInst.airdropTokens(communityId, JSON.stringify(airdropTokens), JSON.stringify(addresses))
|
|
}
|
|
|
|
function computeAirdropFee(communityId, contractKeysAndAmounts, addresses, feeAccountAddress) {
|
|
// TODO: Take `feeAccountAddress` into account when calculating fee
|
|
communityTokensModuleInst.computeAirdropFee(
|
|
communityId, JSON.stringify(contractKeysAndAmounts),
|
|
JSON.stringify(addresses))
|
|
}
|
|
}
|