2024-06-04 13:58:37 +02:00
import QtQuick 2.15
import QtQuick . Controls 2.15
import QtQuick . Layouts 1.15
import StatusQ . Core 0.1
import StatusQ . Popups 0.1
import StatusQ . Controls 0.1
import StatusQ . Components 0.1
import StatusQ . Core . Theme 0.1
2024-06-06 16:05:31 +02:00
import StatusQ . Core . Utils 0.1 as SQUtils
2024-06-04 13:58:37 +02:00
import shared . controls 1.0
import utils 1.0
Control {
id: root
property bool loading
property var selectedToToken
property string toTokenAmount
property alias slippageValue: slippageSelector . value
property alias valid: slippageSelector . valid
QtObject {
id: d
readonly property string selectedToTokenSymbol: ! ! root . selectedToToken && ! ! root . selectedToToken . symbol ?
root.selectedToToken.symbol : ""
}
2024-10-15 21:26:12 +02:00
horizontalPadding: Theme . padding
verticalPadding: Theme . bigPadding
2024-06-04 13:58:37 +02:00
background: Rectangle {
radius: 16
border.width: 1
border.color: Theme . palette . directColor8
color: Theme . palette . indirectColor3
}
contentItem: ColumnLayout {
id: baseLayout
2024-10-15 21:26:12 +02:00
spacing: Theme . bigPadding
2024-06-04 13:58:37 +02:00
RowLayout {
StatusBaseText {
Layout.fillWidth: true
text: qsTr ( "Slippage tolerance" )
font.weight: Font . Medium
lineHeight: button . implicitHeight
lineHeightMode: Text . FixedHeight
verticalAlignment: Text . AlignVCenter
}
StatusLinkText {
id: button
visible: slippageSelector . isEdited
text: qsTr ( "Use default" )
normalColor: Theme . palette . primaryColor1
onClicked: slippageSelector . reset ( )
}
}
StatusBaseText {
Layout.fillWidth: true
Layout.topMargin: - 12
2024-06-19 00:51:49 +02:00
text: qsTr ( "Maximum deviation in price due to market volatility and liquidity allowed before the swap is cancelled. (%L1% default)." ) . arg ( slippageSelector . defaultValue )
2024-06-04 13:58:37 +02:00
wrapMode: Text . Wrap
color: Theme . palette . directColor5
}
/ * T O D O : e r r o r c o n d i t i o n s f o r c u s t o m e n t e r i e s m i s s i n g w i l l b e d o n e u n d e r -
https: //github.com/status-im/status-desktop/issues/15017 */
SlippageSelector {
id: slippageSelector
objectName: "slippageSelector"
Layout.fillWidth: true
}
StatusModalDivider {
Layout.fillWidth: true
Layout.topMargin: 0
2024-10-15 21:26:12 +02:00
Layout.bottomMargin: - Theme . smallPadding
2024-06-04 13:58:37 +02:00
dividerColor: Theme . palette . directColor8
}
RowLayout {
spacing: 4
StatusBaseText {
text: qsTr ( "Receive at least" )
font.pixelSize: 13
font.weight: Font . Medium
}
StatusSmartIdenticon {
2024-10-15 21:26:12 +02:00
Layout.preferredWidth: Theme . padding
Layout.preferredHeight: Theme . padding
2024-06-04 13:58:37 +02:00
asset.name: ! ! root . selectedToToken && ! ! root . selectedToToken . image
? root . selectedToToken . image
: Constants . tokenIcon ( d . selectedToTokenSymbol )
asset.isImage: true
}
StatusTextWithLoadingState {
text: {
2024-06-25 15:37:42 +02:00
const amount = ! ! root . toTokenAmount ? SQUtils . AmountsArithmetic . fromString ( root . toTokenAmount ) . times ( 1 - slippageSelector . value / 100 )
: 0
return ( "%1 %2" ) . arg ( LocaleUtils . numberToLocaleString ( amount . toFixed ( ) ) ) . arg ( d . selectedToTokenSymbol )
2024-06-04 13:58:37 +02:00
}
font.pixelSize: 13
font.weight: Font . Medium
loading: root . loading
}
}
}
}