mirror of
https://github.com/corda/corda.git
synced 2025-01-20 03:36:29 +00:00
Bug Fixes [CORDA-282] - TX id is not rendering properly in new transaction screen (#336)
* Fixed bug [CORDA-282] - TX id is not rendering properly in the New Cash Transaction screen
This commit is contained in:
parent
6362e2ff7c
commit
570b871524
@ -1,10 +1,16 @@
|
|||||||
package net.corda.explorer.views.cordapps.cash
|
package net.corda.explorer.views.cordapps.cash
|
||||||
|
|
||||||
|
import com.google.common.base.Splitter
|
||||||
import javafx.beans.binding.Bindings
|
import javafx.beans.binding.Bindings
|
||||||
import javafx.beans.binding.BooleanBinding
|
import javafx.beans.binding.BooleanBinding
|
||||||
import javafx.beans.property.SimpleObjectProperty
|
import javafx.beans.property.SimpleObjectProperty
|
||||||
import javafx.collections.FXCollections
|
import javafx.collections.FXCollections
|
||||||
|
import javafx.geometry.Insets
|
||||||
|
import javafx.geometry.VPos
|
||||||
import javafx.scene.control.*
|
import javafx.scene.control.*
|
||||||
|
import javafx.scene.layout.GridPane
|
||||||
|
import javafx.scene.text.Font
|
||||||
|
import javafx.scene.text.FontWeight
|
||||||
import javafx.stage.Window
|
import javafx.stage.Window
|
||||||
import net.corda.client.fxutils.ChosenList
|
import net.corda.client.fxutils.ChosenList
|
||||||
import net.corda.client.fxutils.isNotNull
|
import net.corda.client.fxutils.isNotNull
|
||||||
@ -22,7 +28,7 @@ import net.corda.core.getOrThrow
|
|||||||
import net.corda.core.messaging.startFlow
|
import net.corda.core.messaging.startFlow
|
||||||
import net.corda.core.node.NodeInfo
|
import net.corda.core.node.NodeInfo
|
||||||
import net.corda.core.serialization.OpaqueBytes
|
import net.corda.core.serialization.OpaqueBytes
|
||||||
import net.corda.core.transactions.SignedTransaction
|
import net.corda.core.then
|
||||||
import net.corda.explorer.model.CashTransaction
|
import net.corda.explorer.model.CashTransaction
|
||||||
import net.corda.explorer.model.IssuerModel
|
import net.corda.explorer.model.IssuerModel
|
||||||
import net.corda.explorer.model.ReportingCurrencyModel
|
import net.corda.explorer.model.ReportingCurrencyModel
|
||||||
@ -32,8 +38,7 @@ import net.corda.explorer.views.stringConverter
|
|||||||
import net.corda.flows.CashFlowCommand
|
import net.corda.flows.CashFlowCommand
|
||||||
import net.corda.flows.IssuerFlow.IssuanceRequester
|
import net.corda.flows.IssuerFlow.IssuanceRequester
|
||||||
import org.controlsfx.dialog.ExceptionDialog
|
import org.controlsfx.dialog.ExceptionDialog
|
||||||
import tornadofx.Fragment
|
import tornadofx.*
|
||||||
import tornadofx.booleanBinding
|
|
||||||
import java.math.BigDecimal
|
import java.math.BigDecimal
|
||||||
import java.util.*
|
import java.util.*
|
||||||
|
|
||||||
@ -70,7 +75,7 @@ class NewTransaction : Fragment() {
|
|||||||
private val transactionTypes by observableList(IssuerModel::transactionTypes)
|
private val transactionTypes by observableList(IssuerModel::transactionTypes)
|
||||||
|
|
||||||
private val currencyItems = ChosenList(transactionTypeCB.valueProperty().map {
|
private val currencyItems = ChosenList(transactionTypeCB.valueProperty().map {
|
||||||
when(it){
|
when (it) {
|
||||||
CashTransaction.Pay -> supportedCurrencies
|
CashTransaction.Pay -> supportedCurrencies
|
||||||
CashTransaction.Issue,
|
CashTransaction.Issue,
|
||||||
CashTransaction.Exit -> currencyTypes
|
CashTransaction.Exit -> currencyTypes
|
||||||
@ -79,56 +84,60 @@ class NewTransaction : Fragment() {
|
|||||||
})
|
})
|
||||||
|
|
||||||
fun show(window: Window): Unit {
|
fun show(window: Window): Unit {
|
||||||
dialog(window).showAndWait().ifPresent {
|
newTransactionDialog(window).showAndWait().ifPresent { command ->
|
||||||
val dialog = Alert(Alert.AlertType.INFORMATION).apply {
|
val dialog = Alert(Alert.AlertType.INFORMATION).apply {
|
||||||
headerText = null
|
headerText = null
|
||||||
contentText = "Transaction Started."
|
contentText = "Transaction Started."
|
||||||
dialogPane.isDisable = true
|
dialogPane.isDisable = true
|
||||||
initOwner(window)
|
initOwner(window)
|
||||||
|
show()
|
||||||
|
}
|
||||||
|
val handle = if (command is CashFlowCommand.IssueCash) {
|
||||||
|
rpcProxy.value!!.startFlow(::IssuanceRequester,
|
||||||
|
command.amount,
|
||||||
|
command.recipient,
|
||||||
|
command.issueRef,
|
||||||
|
myIdentity.value!!.legalIdentity)
|
||||||
|
} else {
|
||||||
|
command.startFlow(rpcProxy.value!!)
|
||||||
}
|
}
|
||||||
dialog.show()
|
|
||||||
runAsync {
|
runAsync {
|
||||||
val handle = if (it is CashFlowCommand.IssueCash) {
|
handle.returnValue.then { dialog.dialogPane.isDisable = false }.getOrThrow()
|
||||||
myIdentity.value?.let { myIdentity ->
|
|
||||||
rpcProxy.value!!.startFlow(::IssuanceRequester,
|
|
||||||
it.amount,
|
|
||||||
it.recipient,
|
|
||||||
it.issueRef,
|
|
||||||
myIdentity.legalIdentity)
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
it.startFlow(rpcProxy.value!!)
|
|
||||||
}
|
|
||||||
val response = try {
|
|
||||||
handle?.returnValue?.getOrThrow()
|
|
||||||
} catch (e: FlowException) {
|
|
||||||
e
|
|
||||||
}
|
|
||||||
it to response
|
|
||||||
}.ui {
|
}.ui {
|
||||||
val (command, response) = it
|
val type = when (command) {
|
||||||
val (alertType, contentText) = if (response is FlowException) {
|
is CashFlowCommand.IssueCash -> "Cash Issued"
|
||||||
Alert.AlertType.ERROR to response.message
|
is CashFlowCommand.ExitCash -> "Cash Exited"
|
||||||
} else {
|
is CashFlowCommand.PayCash -> "Cash Paid"
|
||||||
val type = when (command) {
|
}
|
||||||
is CashFlowCommand.IssueCash -> "Cash Issued"
|
dialog.alertType = Alert.AlertType.INFORMATION
|
||||||
is CashFlowCommand.ExitCash -> "Cash Exited"
|
dialog.dialogPane.content = gridpane {
|
||||||
is CashFlowCommand.PayCash -> "Cash Paid"
|
padding = Insets(10.0, 40.0, 10.0, 20.0)
|
||||||
}
|
vgap = 10.0
|
||||||
Alert.AlertType.INFORMATION to "$type \nTransaction ID : ${(response as SignedTransaction).id}"
|
hgap = 10.0
|
||||||
|
row { label(type) { font = Font.font(font.family, FontWeight.EXTRA_BOLD, font.size + 2) } }
|
||||||
|
row {
|
||||||
|
label("Transaction ID :") { GridPane.setValignment(this, VPos.TOP) }
|
||||||
|
label { text = Splitter.fixedLength(16).split("${it.id}").joinToString("\n") }
|
||||||
|
}
|
||||||
}
|
}
|
||||||
dialog.alertType = alertType
|
|
||||||
dialog.contentText = contentText
|
|
||||||
dialog.dialogPane.isDisable = false
|
|
||||||
dialog.dialogPane.scene.window.sizeToScene()
|
dialog.dialogPane.scene.window.sizeToScene()
|
||||||
}.setOnFailed {
|
}.setOnFailed {
|
||||||
dialog.close()
|
val ex = it.source.exception
|
||||||
ExceptionDialog(it.source.exception).apply { initOwner(window) }.showAndWait()
|
when (ex) {
|
||||||
|
is FlowException -> {
|
||||||
|
dialog.alertType = Alert.AlertType.ERROR
|
||||||
|
dialog.contentText = ex.message
|
||||||
|
}
|
||||||
|
else -> {
|
||||||
|
dialog.close()
|
||||||
|
ExceptionDialog(ex).apply { initOwner(window) }.showAndWait()
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private fun dialog(window: Window) = Dialog<CashFlowCommand>().apply {
|
private fun newTransactionDialog(window: Window) = Dialog<CashFlowCommand>().apply {
|
||||||
dialogPane = root
|
dialogPane = root
|
||||||
initOwner(window)
|
initOwner(window)
|
||||||
setResultConverter {
|
setResultConverter {
|
||||||
|
Loading…
Reference in New Issue
Block a user