@prohetamine/redstone 0.0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (160) hide show
  1. package/dist/PhArrowCircleDown-BR-zH4LC.js +14 -0
  2. package/dist/PhArrowCircleDown-Sb38khBy.mjs +73 -0
  3. package/dist/PhArrowClockwise-BE5j9P0Z.mjs +73 -0
  4. package/dist/PhArrowClockwise-BRaehQGe.js +14 -0
  5. package/dist/PhArrowDown-B_WmmmY9.js +14 -0
  6. package/dist/PhArrowDown-CFEyR2dR.mjs +73 -0
  7. package/dist/PhArrowLeft-CYfU7NZj.mjs +73 -0
  8. package/dist/PhArrowLeft-CkEd70hm.js +14 -0
  9. package/dist/PhArrowRight-C07Qkx86.js +14 -0
  10. package/dist/PhArrowRight-EermNu0V.mjs +73 -0
  11. package/dist/PhArrowSquareOut-BjTBfzOP.js +14 -0
  12. package/dist/PhArrowSquareOut-DZwTtw54.mjs +73 -0
  13. package/dist/PhArrowUp-DB4CCSss.js +14 -0
  14. package/dist/PhArrowUp-xTpLFQkg.mjs +73 -0
  15. package/dist/PhArrowUpRight-CQbvn6NO.mjs +73 -0
  16. package/dist/PhArrowUpRight-GpCIMsAh.js +14 -0
  17. package/dist/PhArrowsClockwise-BgcIUg-Z.js +14 -0
  18. package/dist/PhArrowsClockwise-DnUYZTVx.mjs +73 -0
  19. package/dist/PhArrowsDownUp-C8KXUqtu.js +14 -0
  20. package/dist/PhArrowsDownUp-DgoprEe2.mjs +73 -0
  21. package/dist/PhArrowsLeftRight-CahChzCj.js +14 -0
  22. package/dist/PhArrowsLeftRight-FD4AZiLh.mjs +73 -0
  23. package/dist/PhBank-DIqIL4x_.js +14 -0
  24. package/dist/PhBank-DbQOQ9zJ.mjs +73 -0
  25. package/dist/PhBrowser-BCBXK2IM.mjs +73 -0
  26. package/dist/PhBrowser-laCKtn7T.js +14 -0
  27. package/dist/PhCaretDown-CnjP-QjZ.mjs +73 -0
  28. package/dist/PhCaretDown-DDe42xDU.js +14 -0
  29. package/dist/PhCaretLeft-Cskc5OY9.js +14 -0
  30. package/dist/PhCaretLeft-DkuXxjf_.mjs +73 -0
  31. package/dist/PhCaretRight-CBWpghxt.mjs +73 -0
  32. package/dist/PhCaretRight-DNgI5w_B.js +14 -0
  33. package/dist/PhCaretUp-CQ-OztBV.mjs +73 -0
  34. package/dist/PhCaretUp-CUZ4g_Me.js +14 -0
  35. package/dist/PhCheck-BVV_Dwfo.js +14 -0
  36. package/dist/PhCheck-t515emYS.mjs +73 -0
  37. package/dist/PhCircleHalf-BuQTmrKW.mjs +73 -0
  38. package/dist/PhCircleHalf-DDC7rige.js +14 -0
  39. package/dist/PhClock-BqynEKWl.js +14 -0
  40. package/dist/PhClock-D6XkTmM_.mjs +73 -0
  41. package/dist/PhCompass-2QeeX5Ad.mjs +73 -0
  42. package/dist/PhCompass-BsuJwXAE.js +14 -0
  43. package/dist/PhCopy-CO34-_xD.mjs +73 -0
  44. package/dist/PhCopy-MVqtRS6X.js +14 -0
  45. package/dist/PhCreditCard-Dq4kdjCw.js +14 -0
  46. package/dist/PhCreditCard-bfnqYflD.mjs +73 -0
  47. package/dist/PhCurrencyDollar-6k8UWxal.js +14 -0
  48. package/dist/PhCurrencyDollar-BekVYPtC.mjs +73 -0
  49. package/dist/PhDesktop-BkNzf3rT.mjs +73 -0
  50. package/dist/PhDesktop-CfsXQ0vC.js +14 -0
  51. package/dist/PhDeviceMobile-BT3Mg_b0.mjs +73 -0
  52. package/dist/PhDeviceMobile-BnrrDrwf.js +14 -0
  53. package/dist/PhDotsThree-6LRvhAcL.js +14 -0
  54. package/dist/PhDotsThree-kpf2OKxJ.mjs +73 -0
  55. package/dist/PhEnvelope-CHsfC2e0.js +14 -0
  56. package/dist/PhEnvelope-UFKpKtwf.mjs +73 -0
  57. package/dist/PhFunnelSimple-CdAqSIhK.mjs +73 -0
  58. package/dist/PhFunnelSimple-JAk7X9Wo.js +14 -0
  59. package/dist/PhGlobe-B3RYXl8h.mjs +73 -0
  60. package/dist/PhGlobe-Tfs4MfpG.js +14 -0
  61. package/dist/PhIdentificationCard-Dqmd6eY1.js +14 -0
  62. package/dist/PhIdentificationCard-rSq59Czm.mjs +73 -0
  63. package/dist/PhImage-aEryzfCi.js +14 -0
  64. package/dist/PhImage-ynsEnFd_.mjs +73 -0
  65. package/dist/PhInfo-B7lsWl6m.mjs +73 -0
  66. package/dist/PhInfo-D6oUrWpA.js +14 -0
  67. package/dist/PhLightbulb-FQDaMMqu.mjs +73 -0
  68. package/dist/PhLightbulb-qbEduhPa.js +14 -0
  69. package/dist/PhMagnifyingGlass-COdRH2k5.js +14 -0
  70. package/dist/PhMagnifyingGlass-_NXk13-0.mjs +73 -0
  71. package/dist/PhPaperPlaneRight-BYi7SorW.mjs +73 -0
  72. package/dist/PhPaperPlaneRight-DrpVAQOZ.js +14 -0
  73. package/dist/PhPlus-25KQTPHG.mjs +73 -0
  74. package/dist/PhPlus-BhUXef08.js +14 -0
  75. package/dist/PhPower-BKl7gzsB.mjs +73 -0
  76. package/dist/PhPower-BNJf1AGQ.js +14 -0
  77. package/dist/PhPuzzlePiece-BkZeF8CX.js +14 -0
  78. package/dist/PhPuzzlePiece-BqUI4GRs.mjs +73 -0
  79. package/dist/PhQrCode-C-tqZKPP.mjs +73 -0
  80. package/dist/PhQrCode-C0v0iXQN.js +14 -0
  81. package/dist/PhQuestion-BBAiRWgt.js +14 -0
  82. package/dist/PhQuestion-CtYvffyD.mjs +73 -0
  83. package/dist/PhQuestionMark-BNbtL2yx.mjs +73 -0
  84. package/dist/PhQuestionMark-BvGUBZ1h.js +14 -0
  85. package/dist/PhSealCheck-B0TEqWpq.mjs +73 -0
  86. package/dist/PhSealCheck-BwNkuF7G.js +14 -0
  87. package/dist/PhSignOut-C1rMSNaS.js +14 -0
  88. package/dist/PhSignOut-HX2_BVsD.mjs +73 -0
  89. package/dist/PhSpinner-CoDYLYOX.mjs +73 -0
  90. package/dist/PhSpinner-nmsGWDQl.js +14 -0
  91. package/dist/PhTrash-CALlKx3e.js +14 -0
  92. package/dist/PhTrash-DeQHS8ZP.mjs +73 -0
  93. package/dist/PhUser-CA0e5OPI.js +14 -0
  94. package/dist/PhUser-Cy5EY3vX.mjs +73 -0
  95. package/dist/PhVault-DdXjVOO9.mjs +73 -0
  96. package/dist/PhVault-DqxV75cz.js +14 -0
  97. package/dist/PhWallet-CeQrfGYc.mjs +73 -0
  98. package/dist/PhWallet-CyCuEs2U.js +14 -0
  99. package/dist/PhWarning-BKaHv_wT.mjs +73 -0
  100. package/dist/PhWarning-C7oj86bY.js +14 -0
  101. package/dist/PhWarningCircle-8MWw-QgE.mjs +73 -0
  102. package/dist/PhWarningCircle-CrNPXGj4.js +14 -0
  103. package/dist/PhX-9lsrXjyl.js +14 -0
  104. package/dist/PhX-DgXr_Fb0.mjs +73 -0
  105. package/dist/ReownAuthentication-Bfv31LzI.mjs +274 -0
  106. package/dist/ReownAuthentication-d8aYgGOq.js +5 -0
  107. package/dist/SwapController-4lzoYsYr.js +1 -0
  108. package/dist/SwapController-DjzUWRyQ.mjs +462 -0
  109. package/dist/ccip-CvwbEhki.js +1 -0
  110. package/dist/ccip-TuO68NeE.mjs +150 -0
  111. package/dist/data-capture-BwdjH2vc.mjs +489 -0
  112. package/dist/data-capture-xVUNZJ2T.js +242 -0
  113. package/dist/email-BCZObJCY.js +90 -0
  114. package/dist/email-m-wo60fN.mjs +338 -0
  115. package/dist/embedded-wallet-CGSri-4g.js +410 -0
  116. package/dist/embedded-wallet-DdZmv5qP.mjs +808 -0
  117. package/dist/features-BJ8kNaE8.js +1 -0
  118. package/dist/features-CJ34oImB.mjs +6 -0
  119. package/dist/index-4lfXeo30.js +132 -0
  120. package/dist/index-B6Mg114Z.mjs +69182 -0
  121. package/dist/index-BX7gAgT3.mjs +35 -0
  122. package/dist/index-BYQqNbCe.js +1 -0
  123. package/dist/index-BmdHwtJo.js +1 -0
  124. package/dist/index-BvUx3ULC.js +78 -0
  125. package/dist/index-CD-QGO70.mjs +196 -0
  126. package/dist/index-CJtXfdoM.mjs +29621 -0
  127. package/dist/index-CMzdgE-y.mjs +215 -0
  128. package/dist/index-CjZQCcwG.js +7203 -0
  129. package/dist/index-D7VuOaCI.js +19 -0
  130. package/dist/index-DV7SQwgn.mjs +2688 -0
  131. package/dist/index-DVf4BnNh.mjs +352 -0
  132. package/dist/index-DhN9vL4k.js +138 -0
  133. package/dist/index-DvllakY0.mjs +274 -0
  134. package/dist/index-Ho06VKh2.mjs +151 -0
  135. package/dist/index-a8mS2Eh1.js +1062 -0
  136. package/dist/index-aamBi9Tu.js +1 -0
  137. package/dist/index.cjs.js +1 -0
  138. package/dist/index.es.js +14 -0
  139. package/dist/onramp-DLlhSPQg.js +422 -0
  140. package/dist/onramp-k-EAEepC.mjs +842 -0
  141. package/dist/parseSignature-D1tZHglo.js +16 -0
  142. package/dist/parseSignature-DM0lwcDr.mjs +8883 -0
  143. package/dist/pay-with-exchange---G2M1Ag.js +280 -0
  144. package/dist/pay-with-exchange-CFIcUXUe.mjs +512 -0
  145. package/dist/property-Bd8U3_QP.mjs +618 -0
  146. package/dist/property-DissjCbZ.js +27 -0
  147. package/dist/receive-B9LCljO6.mjs +228 -0
  148. package/dist/receive-E8H6GDOX.js +131 -0
  149. package/dist/send-B-AooLph.js +554 -0
  150. package/dist/send-DZd_xhsd.mjs +1155 -0
  151. package/dist/socials-ChWFLEFe.mjs +611 -0
  152. package/dist/socials-YSUYSh8o.js +250 -0
  153. package/dist/swaps-DpR9W9Ld.js +1050 -0
  154. package/dist/swaps-Du7-Ui_V.mjs +1752 -0
  155. package/dist/transactions-DhsK5-QJ.mjs +35 -0
  156. package/dist/transactions-VPsz2OLe.js +16 -0
  157. package/dist/w3m-modal-DhomfjKU.js +891 -0
  158. package/dist/w3m-modal-KuYD-zqQ.mjs +1759 -0
  159. package/package.json +51 -0
  160. package/readme.md +1 -0
@@ -0,0 +1,1050 @@
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const t=require("./index-CjZQCcwG.js"),s=require("./SwapController-4lzoYsYr.js");require("./index-DhN9vL4k.js");const I={numericInputKeyDown(e,o,i){const n=["Backspace","Meta","Ctrl","a","A","c","C","x","X","v","V","ArrowLeft","ArrowRight","Tab"],a=e.metaKey||e.ctrlKey,r=e.key,l=r.toLocaleLowerCase(),c=l==="a",h=l==="c",k=l==="v",y=l==="x",T=r===",",S=r===".",C=r>="0"&&r<="9";!a&&(c||h||k||y)&&e.preventDefault(),o==="0"&&!T&&!S&&r==="0"&&e.preventDefault(),o==="0"&&C&&(i(r),e.preventDefault()),(T||S)&&(o||(i("0."),e.preventDefault()),(o!=null&&o.includes(".")||o!=null&&o.includes(","))&&e.preventDefault()),!C&&!n.includes(r)&&!S&&!T&&e.preventDefault()}},A=t.css`
2
+ :host {
3
+ width: 100%;
4
+ }
5
+
6
+ .details-container > wui-flex {
7
+ background: ${({tokens:e})=>e.theme.foregroundPrimary};
8
+ border-radius: ${({borderRadius:e})=>e[3]};
9
+ width: 100%;
10
+ }
11
+
12
+ .details-container > wui-flex > button {
13
+ border: none;
14
+ background: none;
15
+ padding: ${({spacing:e})=>e[3]};
16
+ border-radius: ${({borderRadius:e})=>e[3]};
17
+ cursor: pointer;
18
+ }
19
+
20
+ .details-content-container {
21
+ padding: ${({spacing:e})=>e[2]};
22
+ padding-top: 0px;
23
+ display: flex;
24
+ align-items: center;
25
+ justify-content: center;
26
+ }
27
+
28
+ .details-content-container > wui-flex {
29
+ width: 100%;
30
+ }
31
+
32
+ .details-row {
33
+ width: 100%;
34
+ padding: ${({spacing:e})=>e[3]};
35
+ padding-left: ${({spacing:e})=>e[3]};
36
+ padding-right: ${({spacing:e})=>e[2]};
37
+ border-radius: calc(
38
+ ${({borderRadius:e})=>e[1]} + ${({borderRadius:e})=>e[1]}
39
+ );
40
+ background: ${({tokens:e})=>e.theme.foregroundPrimary};
41
+ }
42
+
43
+ .details-row-title {
44
+ white-space: nowrap;
45
+ }
46
+
47
+ .details-row.provider-free-row {
48
+ padding-right: ${({spacing:e})=>e[2]};
49
+ }
50
+ `;var m=function(e,o,i,n){var a=arguments.length,r=a<3?o:n===null?n=Object.getOwnPropertyDescriptor(o,i):n,l;if(typeof Reflect=="object"&&typeof Reflect.decorate=="function")r=Reflect.decorate(e,o,i,n);else for(var c=e.length-1;c>=0;c--)(l=e[c])&&(r=(a<3?l(r):a>3?l(o,i,r):l(o,i))||r);return a>3&&r&&Object.defineProperty(o,i,r),r};const D=t.ConstantsUtil$1.CONVERT_SLIPPAGE_TOLERANCE;let d=class extends t.i{constructor(){var o;super(),this.unsubscribe=[],this.networkName=(o=t.ChainController.state.activeCaipNetwork)==null?void 0:o.name,this.detailsOpen=!1,this.sourceToken=s.SwapController.state.sourceToken,this.toToken=s.SwapController.state.toToken,this.toTokenAmount=s.SwapController.state.toTokenAmount,this.sourceTokenPriceInUSD=s.SwapController.state.sourceTokenPriceInUSD,this.toTokenPriceInUSD=s.SwapController.state.toTokenPriceInUSD,this.priceImpact=s.SwapController.state.priceImpact,this.maxSlippage=s.SwapController.state.maxSlippage,this.networkTokenSymbol=s.SwapController.state.networkTokenSymbol,this.inputError=s.SwapController.state.inputError,this.unsubscribe.push(s.SwapController.subscribe(i=>{this.sourceToken=i.sourceToken,this.toToken=i.toToken,this.toTokenAmount=i.toTokenAmount,this.priceImpact=i.priceImpact,this.maxSlippage=i.maxSlippage,this.sourceTokenPriceInUSD=i.sourceTokenPriceInUSD,this.toTokenPriceInUSD=i.toTokenPriceInUSD,this.inputError=i.inputError}))}render(){const o=this.toTokenAmount&&this.maxSlippage?t.NumberUtil.bigNumber(this.toTokenAmount).minus(this.maxSlippage).toString():null;if(!this.sourceToken||!this.toToken||this.inputError)return null;const i=this.sourceTokenPriceInUSD&&this.toTokenPriceInUSD?1/this.toTokenPriceInUSD*this.sourceTokenPriceInUSD:0;return t.b`
51
+ <wui-flex flexDirection="column" alignItems="center" gap="01" class="details-container">
52
+ <wui-flex flexDirection="column">
53
+ <button @click=${this.toggleDetails.bind(this)}>
54
+ <wui-flex justifyContent="space-between" .padding=${["0","2","0","2"]}>
55
+ <wui-flex justifyContent="flex-start" flexGrow="1" gap="2">
56
+ <wui-text variant="sm-regular" color="primary">
57
+ 1 ${this.sourceToken.symbol} =
58
+ ${t.NumberUtil.formatNumberToLocalString(i,3)}
59
+ ${this.toToken.symbol}
60
+ </wui-text>
61
+ <wui-text variant="sm-regular" color="secondary">
62
+ $${t.NumberUtil.formatNumberToLocalString(this.sourceTokenPriceInUSD)}
63
+ </wui-text>
64
+ </wui-flex>
65
+ <wui-icon name="chevronBottom"></wui-icon>
66
+ </wui-flex>
67
+ </button>
68
+ ${this.detailsOpen?t.b`
69
+ <wui-flex flexDirection="column" gap="2" class="details-content-container">
70
+ ${this.priceImpact?t.b` <wui-flex flexDirection="column" gap="2">
71
+ <wui-flex
72
+ justifyContent="space-between"
73
+ alignItems="center"
74
+ class="details-row"
75
+ >
76
+ <wui-flex alignItems="center" gap="2">
77
+ <wui-text
78
+ class="details-row-title"
79
+ variant="sm-regular"
80
+ color="secondary"
81
+ >
82
+ Price impact
83
+ </wui-text>
84
+ <w3m-tooltip-trigger
85
+ text="Price impact reflects the change in market price due to your trade"
86
+ >
87
+ <wui-icon size="sm" color="default" name="info"></wui-icon>
88
+ </w3m-tooltip-trigger>
89
+ </wui-flex>
90
+ <wui-flex>
91
+ <wui-text variant="sm-regular" color="secondary">
92
+ ${t.NumberUtil.formatNumberToLocalString(this.priceImpact,3)}%
93
+ </wui-text>
94
+ </wui-flex>
95
+ </wui-flex>
96
+ </wui-flex>`:null}
97
+ ${this.maxSlippage&&this.sourceToken.symbol?t.b`<wui-flex flexDirection="column" gap="2">
98
+ <wui-flex
99
+ justifyContent="space-between"
100
+ alignItems="center"
101
+ class="details-row"
102
+ >
103
+ <wui-flex alignItems="center" gap="2">
104
+ <wui-text
105
+ class="details-row-title"
106
+ variant="sm-regular"
107
+ color="secondary"
108
+ >
109
+ Max. slippage
110
+ </wui-text>
111
+ <w3m-tooltip-trigger
112
+ text=${`Max slippage sets the minimum amount you must receive for the transaction to proceed. ${o?`Transaction will be reversed if you receive less than ${t.NumberUtil.formatNumberToLocalString(o,6)} ${this.toToken.symbol} due to price changes.`:""}`}
113
+ >
114
+ <wui-icon size="sm" color="default" name="info"></wui-icon>
115
+ </w3m-tooltip-trigger>
116
+ </wui-flex>
117
+ <wui-flex>
118
+ <wui-text variant="sm-regular" color="secondary">
119
+ ${t.NumberUtil.formatNumberToLocalString(this.maxSlippage,6)}
120
+ ${this.toToken.symbol} ${D}%
121
+ </wui-text>
122
+ </wui-flex>
123
+ </wui-flex>
124
+ </wui-flex>`:null}
125
+ <wui-flex flexDirection="column" gap="2">
126
+ <wui-flex
127
+ justifyContent="space-between"
128
+ alignItems="center"
129
+ class="details-row provider-free-row"
130
+ >
131
+ <wui-flex alignItems="center" gap="2">
132
+ <wui-text class="details-row-title" variant="sm-regular" color="secondary">
133
+ Provider fee
134
+ </wui-text>
135
+ </wui-flex>
136
+ <wui-flex>
137
+ <wui-text variant="sm-regular" color="secondary">0.85%</wui-text>
138
+ </wui-flex>
139
+ </wui-flex>
140
+ </wui-flex>
141
+ </wui-flex>
142
+ `:null}
143
+ </wui-flex>
144
+ </wui-flex>
145
+ `}toggleDetails(){this.detailsOpen=!this.detailsOpen}};d.styles=[A];m([t.r()],d.prototype,"networkName",void 0);m([t.n()],d.prototype,"detailsOpen",void 0);m([t.r()],d.prototype,"sourceToken",void 0);m([t.r()],d.prototype,"toToken",void 0);m([t.r()],d.prototype,"toTokenAmount",void 0);m([t.r()],d.prototype,"sourceTokenPriceInUSD",void 0);m([t.r()],d.prototype,"toTokenPriceInUSD",void 0);m([t.r()],d.prototype,"priceImpact",void 0);m([t.r()],d.prototype,"maxSlippage",void 0);m([t.r()],d.prototype,"networkTokenSymbol",void 0);m([t.r()],d.prototype,"inputError",void 0);d=m([t.customElement("w3m-swap-details")],d);const W=t.css`
146
+ :host {
147
+ width: 100%;
148
+ }
149
+
150
+ :host > wui-flex {
151
+ display: flex;
152
+ flex-direction: row;
153
+ justify-content: space-between;
154
+ align-items: center;
155
+ border-radius: ${({borderRadius:e})=>e[5]};
156
+ padding: ${({spacing:e})=>e[5]};
157
+ padding-right: ${({spacing:e})=>e[3]};
158
+ background-color: ${({tokens:e})=>e.theme.foregroundPrimary};
159
+ box-shadow: inset 0px 0px 0px 1px ${({tokens:e})=>e.theme.foregroundPrimary};
160
+ width: 100%;
161
+ height: 100px;
162
+ box-sizing: border-box;
163
+ position: relative;
164
+ }
165
+
166
+ wui-shimmer.market-value {
167
+ opacity: 0;
168
+ }
169
+
170
+ :host > wui-flex > svg.input_mask {
171
+ position: absolute;
172
+ inset: 0;
173
+ z-index: 5;
174
+ }
175
+
176
+ :host wui-flex .input_mask__border,
177
+ :host wui-flex .input_mask__background {
178
+ transition: fill ${({durations:e})=>e.md}
179
+ ${({easings:e})=>e["ease-out-power-1"]};
180
+ will-change: fill;
181
+ }
182
+
183
+ :host wui-flex .input_mask__border {
184
+ fill: ${({tokens:e})=>e.core.glass010};
185
+ }
186
+
187
+ :host wui-flex .input_mask__background {
188
+ fill: ${({tokens:e})=>e.theme.foregroundPrimary};
189
+ }
190
+ `;var P=function(e,o,i,n){var a=arguments.length,r=a<3?o:n===null?n=Object.getOwnPropertyDescriptor(o,i):n,l;if(typeof Reflect=="object"&&typeof Reflect.decorate=="function")r=Reflect.decorate(e,o,i,n);else for(var c=e.length-1;c>=0;c--)(l=e[c])&&(r=(a<3?l(r):a>3?l(o,i,r):l(o,i))||r);return a>3&&r&&Object.defineProperty(o,i,r),r};let v=class extends t.i{constructor(){super(...arguments),this.target="sourceToken"}render(){return t.b`
191
+ <wui-flex class justifyContent="space-between">
192
+ <wui-flex
193
+ flex="1"
194
+ flexDirection="column"
195
+ alignItems="flex-start"
196
+ justifyContent="center"
197
+ class="swap-input"
198
+ gap="1"
199
+ >
200
+ <wui-shimmer width="80px" height="40px" rounded variant="light"></wui-shimmer>
201
+ </wui-flex>
202
+ ${this.templateTokenSelectButton()}
203
+ </wui-flex>
204
+ `}templateTokenSelectButton(){return t.b`
205
+ <wui-flex
206
+ class="swap-token-button"
207
+ flexDirection="column"
208
+ alignItems="flex-end"
209
+ justifyContent="center"
210
+ gap="1"
211
+ >
212
+ <wui-shimmer width="80px" height="40px" rounded variant="light"></wui-shimmer>
213
+ </wui-flex>
214
+ `}};v.styles=[W];P([t.n()],v.prototype,"target",void 0);v=P([t.customElement("w3m-swap-input-skeleton")],v);const U=t.css`
215
+ :host > wui-flex {
216
+ display: flex;
217
+ flex-direction: row;
218
+ justify-content: space-between;
219
+ align-items: center;
220
+ border-radius: ${({borderRadius:e})=>e[5]};
221
+ background-color: ${({tokens:e})=>e.theme.foregroundPrimary};
222
+ padding: ${({spacing:e})=>e[5]};
223
+ padding-right: ${({spacing:e})=>e[3]};
224
+ width: 100%;
225
+ height: 100px;
226
+ box-sizing: border-box;
227
+ box-shadow: inset 0px 0px 0px 1px ${({tokens:e})=>e.theme.foregroundPrimary};
228
+ position: relative;
229
+ transition: box-shadow ${({easings:e})=>e["ease-out-power-1"]}
230
+ ${({durations:e})=>e.lg};
231
+ will-change: background-color;
232
+ }
233
+
234
+ :host wui-flex.focus {
235
+ box-shadow: inset 0px 0px 0px 1px ${({tokens:e})=>e.core.glass010};
236
+ }
237
+
238
+ :host > wui-flex .swap-input,
239
+ :host > wui-flex .swap-token-button {
240
+ z-index: 10;
241
+ }
242
+
243
+ :host > wui-flex .swap-input {
244
+ -webkit-mask-image: linear-gradient(
245
+ 270deg,
246
+ transparent 0px,
247
+ transparent 8px,
248
+ black 24px,
249
+ black 25px,
250
+ black 32px,
251
+ black 100%
252
+ );
253
+ mask-image: linear-gradient(
254
+ 270deg,
255
+ transparent 0px,
256
+ transparent 8px,
257
+ black 24px,
258
+ black 25px,
259
+ black 32px,
260
+ black 100%
261
+ );
262
+ }
263
+
264
+ :host > wui-flex .swap-input input {
265
+ background: none;
266
+ border: none;
267
+ height: 42px;
268
+ width: 100%;
269
+ font-size: 32px;
270
+ font-style: normal;
271
+ font-weight: 400;
272
+ line-height: 130%;
273
+ letter-spacing: -1.28px;
274
+ outline: none;
275
+ caret-color: ${({tokens:e})=>e.core.textAccentPrimary};
276
+ color: ${({tokens:e})=>e.theme.textPrimary};
277
+ padding: 0px;
278
+ }
279
+
280
+ :host > wui-flex .swap-input input:focus-visible {
281
+ outline: none;
282
+ }
283
+
284
+ :host > wui-flex .swap-input input::-webkit-outer-spin-button,
285
+ :host > wui-flex .swap-input input::-webkit-inner-spin-button {
286
+ -webkit-appearance: none;
287
+ margin: 0;
288
+ }
289
+
290
+ .max-value-button {
291
+ background-color: transparent;
292
+ border: none;
293
+ cursor: pointer;
294
+ color: ${({tokens:e})=>e.core.glass010};
295
+ padding-left: 0px;
296
+ }
297
+
298
+ .market-value {
299
+ min-height: 18px;
300
+ }
301
+ `;var f=function(e,o,i,n){var a=arguments.length,r=a<3?o:n===null?n=Object.getOwnPropertyDescriptor(o,i):n,l;if(typeof Reflect=="object"&&typeof Reflect.decorate=="function")r=Reflect.decorate(e,o,i,n);else for(var c=e.length-1;c>=0;c--)(l=e[c])&&(r=(a<3?l(r):a>3?l(o,i,r):l(o,i))||r);return a>3&&r&&Object.defineProperty(o,i,r),r};const V=5e-5;let w=class extends t.i{constructor(){super(...arguments),this.focused=!1,this.price=0,this.target="sourceToken",this.onSetAmount=null,this.onSetMaxValue=null}render(){const o=this.marketValue||"0",i=t.NumberUtil.bigNumber(o).gt("0");return t.b`
302
+ <wui-flex
303
+ class="${this.focused?"focus":""}"
304
+ justifyContent="space-between"
305
+ alignItems="center"
306
+ >
307
+ <wui-flex
308
+ flex="1"
309
+ flexDirection="column"
310
+ alignItems="flex-start"
311
+ justifyContent="center"
312
+ class="swap-input"
313
+ >
314
+ <input
315
+ data-testid="swap-input-${this.target}"
316
+ @focusin=${()=>this.onFocusChange(!0)}
317
+ @focusout=${()=>this.onFocusChange(!1)}
318
+ ?disabled=${this.disabled}
319
+ value=${this.value||""}
320
+ @input=${this.dispatchInputChangeEvent}
321
+ @keydown=${this.handleKeydown}
322
+ placeholder="0"
323
+ type="text"
324
+ inputmode="decimal"
325
+ pattern="[0-9,.]*"
326
+ />
327
+ <wui-text class="market-value" variant="sm-regular" color="secondary">
328
+ ${i?`$${t.NumberUtil.formatNumberToLocalString(this.marketValue,2)}`:null}
329
+ </wui-text>
330
+ </wui-flex>
331
+ ${this.templateTokenSelectButton()}
332
+ </wui-flex>
333
+ `}handleKeydown(o){return I.numericInputKeyDown(o,this.value,i=>{var n;return(n=this.onSetAmount)==null?void 0:n.call(this,this.target,i)})}dispatchInputChangeEvent(o){if(!this.onSetAmount)return;const i=o.target.value.replace(/[^0-9.]/gu,"");i===","||i==="."?this.onSetAmount(this.target,"0."):i.endsWith(",")?this.onSetAmount(this.target,i.replace(",",".")):this.onSetAmount(this.target,i)}setMaxValueToInput(){var o;(o=this.onSetMaxValue)==null||o.call(this,this.target,this.balance)}templateTokenSelectButton(){return this.token?t.b`
334
+ <wui-flex
335
+ class="swap-token-button"
336
+ flexDirection="column"
337
+ alignItems="flex-end"
338
+ justifyContent="center"
339
+ gap="1"
340
+ >
341
+ <wui-token-button
342
+ data-testid="swap-input-token-${this.target}"
343
+ text=${this.token.symbol}
344
+ imageSrc=${this.token.logoUri}
345
+ @click=${this.onSelectToken.bind(this)}
346
+ >
347
+ </wui-token-button>
348
+ <wui-flex alignItems="center" gap="1"> ${this.tokenBalanceTemplate()} </wui-flex>
349
+ </wui-flex>
350
+ `:t.b` <wui-button
351
+ data-testid="swap-select-token-button-${this.target}"
352
+ class="swap-token-button"
353
+ size="md"
354
+ variant="neutral-secondary"
355
+ @click=${this.onSelectToken.bind(this)}
356
+ >
357
+ Select token
358
+ </wui-button>`}tokenBalanceTemplate(){const o=t.NumberUtil.multiply(this.balance,this.price),i=o?o==null?void 0:o.gt(V):!1;return t.b`
359
+ ${i?t.b`<wui-text variant="sm-regular" color="secondary">
360
+ ${t.NumberUtil.formatNumberToLocalString(this.balance,2)}
361
+ </wui-text>`:null}
362
+ ${this.target==="sourceToken"?this.tokenActionButtonTemplate(i):null}
363
+ `}tokenActionButtonTemplate(o){return o?t.b` <button class="max-value-button" @click=${this.setMaxValueToInput.bind(this)}>
364
+ <wui-text color="accent-primary" variant="sm-medium">Max</wui-text>
365
+ </button>`:t.b` <button class="max-value-button" @click=${this.onBuyToken.bind(this)}>
366
+ <wui-text color="accent-primary" variant="sm-medium">Buy</wui-text>
367
+ </button>`}onFocusChange(o){this.focused=o}onSelectToken(){t.EventsController.sendEvent({type:"track",event:"CLICK_SELECT_TOKEN_TO_SWAP"}),t.RouterController.push("SwapSelectToken",{target:this.target})}onBuyToken(){t.RouterController.push("OnRampProviders")}};w.styles=[U];f([t.n()],w.prototype,"focused",void 0);f([t.n()],w.prototype,"balance",void 0);f([t.n()],w.prototype,"value",void 0);f([t.n()],w.prototype,"price",void 0);f([t.n()],w.prototype,"marketValue",void 0);f([t.n()],w.prototype,"disabled",void 0);f([t.n()],w.prototype,"target",void 0);f([t.n()],w.prototype,"token",void 0);f([t.n()],w.prototype,"onSetAmount",void 0);f([t.n()],w.prototype,"onSetMaxValue",void 0);w=f([t.customElement("w3m-swap-input")],w);const E=t.css`
368
+ :host > wui-flex:first-child {
369
+ overflow-y: auto;
370
+ overflow-x: hidden;
371
+ scrollbar-width: none;
372
+ }
373
+
374
+ :host > wui-flex:first-child::-webkit-scrollbar {
375
+ display: none;
376
+ }
377
+
378
+ wui-loading-hexagon {
379
+ position: absolute;
380
+ }
381
+
382
+ .action-button {
383
+ width: 100%;
384
+ border-radius: ${({borderRadius:e})=>e[4]};
385
+ }
386
+
387
+ .action-button:disabled {
388
+ border-color: 1px solid ${({tokens:e})=>e.core.glass010};
389
+ }
390
+
391
+ .swap-inputs-container {
392
+ position: relative;
393
+ }
394
+
395
+ wui-icon-box {
396
+ width: 32px;
397
+ height: 32px;
398
+ border-radius: ${({borderRadius:e})=>e[10]} !important;
399
+ border: 4px solid ${({tokens:e})=>e.theme.backgroundPrimary};
400
+ background: ${({tokens:e})=>e.theme.foregroundPrimary};
401
+ position: absolute;
402
+ top: 50%;
403
+ left: 50%;
404
+ transform: translate(-50%, -50%);
405
+ z-index: 3;
406
+ }
407
+
408
+ .replace-tokens-button-container {
409
+ display: flex;
410
+ justify-content: center;
411
+ align-items: center;
412
+ position: absolute;
413
+ top: 50%;
414
+ left: 50%;
415
+ transform: translate(-50%, -50%);
416
+ gap: ${({spacing:e})=>e[2]};
417
+ border-radius: ${({borderRadius:e})=>e[4]};
418
+ background-color: ${({tokens:e})=>e.theme.backgroundPrimary};
419
+ padding: ${({spacing:e})=>e[2]};
420
+ }
421
+
422
+ .details-container > wui-flex {
423
+ background: ${({tokens:e})=>e.theme.foregroundPrimary};
424
+ border-radius: ${({borderRadius:e})=>e[3]};
425
+ width: 100%;
426
+ }
427
+
428
+ .details-container > wui-flex > button {
429
+ border: none;
430
+ background: none;
431
+ padding: ${({spacing:e})=>e[3]};
432
+ border-radius: ${({borderRadius:e})=>e[3]};
433
+ transition: background ${({durations:e})=>e.lg}
434
+ ${({easings:e})=>e["ease-out-power-2"]};
435
+ will-change: background;
436
+ }
437
+
438
+ .details-container > wui-flex > button:hover {
439
+ background: ${({tokens:e})=>e.theme.foregroundPrimary};
440
+ }
441
+
442
+ .details-content-container {
443
+ padding: ${({spacing:e})=>e[2]};
444
+ display: flex;
445
+ align-items: center;
446
+ justify-content: center;
447
+ }
448
+
449
+ .details-content-container > wui-flex {
450
+ width: 100%;
451
+ }
452
+
453
+ .details-row {
454
+ width: 100%;
455
+ padding: ${({spacing:e})=>e[3]} ${({spacing:e})=>e[5]};
456
+ border-radius: ${({borderRadius:e})=>e[3]};
457
+ background: ${({tokens:e})=>e.theme.foregroundPrimary};
458
+ }
459
+ `;var u=function(e,o,i,n){var a=arguments.length,r=a<3?o:n===null?n=Object.getOwnPropertyDescriptor(o,i):n,l;if(typeof Reflect=="object"&&typeof Reflect.decorate=="function")r=Reflect.decorate(e,o,i,n);else for(var c=e.length-1;c>=0;c--)(l=e[c])&&(r=(a<3?l(r):a>3?l(o,i,r):l(o,i))||r);return a>3&&r&&Object.defineProperty(o,i,r),r};exports.W3mSwapView=class extends t.i{subscribe({resetSwapState:o,initializeSwapState:i}){return()=>{t.ChainController.subscribeKey("activeCaipNetwork",n=>this.onCaipNetworkChange({newCaipNetwork:n,resetSwapState:o,initializeSwapState:i})),t.ChainController.subscribeChainProp("accountState",n=>{this.onCaipAddressChange({newCaipAddress:n==null?void 0:n.caipAddress,resetSwapState:o,initializeSwapState:i})})}}constructor(){var o,i,n;super(),this.unsubscribe=[],this.initialParams=(o=t.RouterController.state.data)==null?void 0:o.swap,this.detailsOpen=!1,this.caipAddress=(i=t.ChainController.getAccountData())==null?void 0:i.caipAddress,this.caipNetworkId=(n=t.ChainController.state.activeCaipNetwork)==null?void 0:n.caipNetworkId,this.initialized=s.SwapController.state.initialized,this.loadingQuote=s.SwapController.state.loadingQuote,this.loadingPrices=s.SwapController.state.loadingPrices,this.loadingTransaction=s.SwapController.state.loadingTransaction,this.sourceToken=s.SwapController.state.sourceToken,this.sourceTokenAmount=s.SwapController.state.sourceTokenAmount,this.sourceTokenPriceInUSD=s.SwapController.state.sourceTokenPriceInUSD,this.toToken=s.SwapController.state.toToken,this.toTokenAmount=s.SwapController.state.toTokenAmount,this.toTokenPriceInUSD=s.SwapController.state.toTokenPriceInUSD,this.inputError=s.SwapController.state.inputError,this.fetchError=s.SwapController.state.fetchError,this.lastTokenPriceUpdate=0,this.minTokenPriceUpdateInterval=1e4,this.visibilityChangeHandler=()=>{document!=null&&document.hidden?(clearInterval(this.interval),this.interval=void 0):this.startTokenPriceInterval()},this.startTokenPriceInterval=()=>{this.interval&&Date.now()-this.lastTokenPriceUpdate<this.minTokenPriceUpdateInterval||(this.lastTokenPriceUpdate&&Date.now()-this.lastTokenPriceUpdate>this.minTokenPriceUpdateInterval&&this.fetchTokensAndValues(),clearInterval(this.interval),this.interval=setInterval(()=>{this.fetchTokensAndValues()},this.minTokenPriceUpdateInterval))},this.watchTokensAndValues=()=>{!this.sourceToken||!this.toToken||(this.subscribeToVisibilityChange(),this.startTokenPriceInterval())},this.onDebouncedGetSwapCalldata=t.CoreHelperUtil.debounce(async()=>{await s.SwapController.swapTokens()},200),this.subscribe({resetSwapState:!0,initializeSwapState:!1})(),this.unsubscribe.push(this.subscribe({resetSwapState:!1,initializeSwapState:!0}),t.ModalController.subscribeKey("open",a=>{a||s.SwapController.resetState()}),t.RouterController.subscribeKey("view",a=>{a.includes("Swap")||s.SwapController.resetValues()}),s.SwapController.subscribe(a=>{this.initialized=a.initialized,this.loadingQuote=a.loadingQuote,this.loadingPrices=a.loadingPrices,this.loadingTransaction=a.loadingTransaction,this.sourceToken=a.sourceToken,this.sourceTokenAmount=a.sourceTokenAmount,this.sourceTokenPriceInUSD=a.sourceTokenPriceInUSD,this.toToken=a.toToken,this.toTokenAmount=a.toTokenAmount,this.toTokenPriceInUSD=a.toTokenPriceInUSD,this.inputError=a.inputError,this.fetchError=a.fetchError,a.sourceToken&&a.toToken&&this.watchTokensAndValues()}))}async firstUpdated(){s.SwapController.initializeState(),this.watchTokensAndValues(),await this.handleSwapParameters()}disconnectedCallback(){this.unsubscribe.forEach(o=>o==null?void 0:o()),clearInterval(this.interval),document==null||document.removeEventListener("visibilitychange",this.visibilityChangeHandler)}render(){return t.b`
460
+ <wui-flex flexDirection="column" .padding=${["0","4","4","4"]} gap="3">
461
+ ${this.initialized?this.templateSwap():this.templateLoading()}
462
+ </wui-flex>
463
+ `}subscribeToVisibilityChange(){document==null||document.removeEventListener("visibilitychange",this.visibilityChangeHandler),document==null||document.addEventListener("visibilitychange",this.visibilityChangeHandler)}fetchTokensAndValues(){s.SwapController.getNetworkTokenPrice(),s.SwapController.getMyTokensWithBalance(),s.SwapController.swapTokens(),this.lastTokenPriceUpdate=Date.now()}templateSwap(){return t.b`
464
+ <wui-flex flexDirection="column" gap="3">
465
+ <wui-flex flexDirection="column" alignItems="center" gap="2" class="swap-inputs-container">
466
+ ${this.templateTokenInput("sourceToken",this.sourceToken)}
467
+ ${this.templateTokenInput("toToken",this.toToken)} ${this.templateReplaceTokensButton()}
468
+ </wui-flex>
469
+ ${this.templateDetails()} ${this.templateActionButton()}
470
+ </wui-flex>
471
+ `}actionButtonLabel(){const o=!this.sourceTokenAmount||this.sourceTokenAmount==="0";return this.fetchError?"Swap":!this.sourceToken||!this.toToken?"Select token":o?"Enter amount":this.inputError?this.inputError:"Review swap"}templateReplaceTokensButton(){return t.b`
472
+ <wui-flex class="replace-tokens-button-container">
473
+ <wui-icon-box
474
+ @click=${this.onSwitchTokens.bind(this)}
475
+ icon="recycleHorizontal"
476
+ size="md"
477
+ variant="default"
478
+ ></wui-icon-box>
479
+ </wui-flex>
480
+ `}templateLoading(){return t.b`
481
+ <wui-flex flexDirection="column" gap="4">
482
+ <wui-flex flexDirection="column" alignItems="center" gap="2" class="swap-inputs-container">
483
+ <w3m-swap-input-skeleton target="sourceToken"></w3m-swap-input-skeleton>
484
+ <w3m-swap-input-skeleton target="toToken"></w3m-swap-input-skeleton>
485
+ ${this.templateReplaceTokensButton()}
486
+ </wui-flex>
487
+ ${this.templateActionButton()}
488
+ </wui-flex>
489
+ `}templateTokenInput(o,i){var c,h;const n=(c=s.SwapController.state.myTokensWithBalance)==null?void 0:c.find(k=>(k==null?void 0:k.address)===(i==null?void 0:i.address)),a=o==="toToken"?this.toTokenAmount:this.sourceTokenAmount,r=o==="toToken"?this.toTokenPriceInUSD:this.sourceTokenPriceInUSD,l=t.NumberUtil.parseLocalStringToNumber(a)*r;return t.b`<w3m-swap-input
490
+ .value=${o==="toToken"?this.toTokenAmount:this.sourceTokenAmount}
491
+ .disabled=${o==="toToken"}
492
+ .onSetAmount=${this.handleChangeAmount.bind(this)}
493
+ target=${o}
494
+ .token=${i}
495
+ .balance=${(h=n==null?void 0:n.quantity)==null?void 0:h.numeric}
496
+ .price=${n==null?void 0:n.price}
497
+ .marketValue=${l}
498
+ .onSetMaxValue=${this.onSetMaxValue.bind(this)}
499
+ ></w3m-swap-input>`}onSetMaxValue(o,i){const n=t.NumberUtil.bigNumber(i||"0");this.handleChangeAmount(o,n.gt(0)?n.toFixed(20):"0")}templateDetails(){return!this.sourceToken||!this.toToken||this.inputError?null:t.b`<w3m-swap-details .detailsOpen=${this.detailsOpen}></w3m-swap-details>`}handleChangeAmount(o,i){s.SwapController.clearError(),o==="sourceToken"?s.SwapController.setSourceTokenAmount(i):s.SwapController.setToTokenAmount(i),this.onDebouncedGetSwapCalldata()}templateActionButton(){const o=!this.toToken||!this.sourceToken,i=!this.sourceTokenAmount||this.sourceTokenAmount==="0",n=this.loadingQuote||this.loadingPrices||this.loadingTransaction,a=n||o||i||this.inputError;return t.b` <wui-flex gap="2">
500
+ <wui-button
501
+ data-testid="swap-action-button"
502
+ class="action-button"
503
+ fullWidth
504
+ size="lg"
505
+ borderRadius="xs"
506
+ variant="accent-primary"
507
+ ?loading=${!!n}
508
+ ?disabled=${!!a}
509
+ @click=${this.onSwapPreview.bind(this)}
510
+ >
511
+ ${this.actionButtonLabel()}
512
+ </wui-button>
513
+ </wui-flex>`}async onSwitchTokens(){await s.SwapController.switchTokens()}async onSwapPreview(){var o,i;this.fetchError&&await s.SwapController.swapTokens(),t.EventsController.sendEvent({type:"track",event:"INITIATE_SWAP",properties:{network:this.caipNetworkId||"",swapFromToken:((o=this.sourceToken)==null?void 0:o.symbol)||"",swapToToken:((i=this.toToken)==null?void 0:i.symbol)||"",swapFromAmount:this.sourceTokenAmount||"",swapToAmount:this.toTokenAmount||"",isSmartAccount:t.getPreferredAccountType(t.ChainController.state.activeChain)===t.W3mFrameRpcConstants.ACCOUNT_TYPES.SMART_ACCOUNT}}),t.RouterController.push("SwapPreview")}async handleSwapParameters(){this.initialParams&&(s.SwapController.state.initialized||await new Promise(i=>{const n=s.SwapController.subscribeKey("initialized",a=>{a&&(n==null||n(),i())})}),await this.setSwapParameters(this.initialParams))}async setSwapParameters({amount:o,fromToken:i,toToken:n}){(!s.SwapController.state.tokens||!s.SwapController.state.myTokensWithBalance)&&await new Promise(l=>{const c=s.SwapController.subscribeKey("myTokensWithBalance",h=>{h&&h.length>0&&(c==null||c(),l())});setTimeout(()=>{c==null||c(),l()},5e3)});const a=[...s.SwapController.state.tokens||[],...s.SwapController.state.myTokensWithBalance||[]];if(i){const r=a.find(l=>l.symbol.toLowerCase()===i.toLowerCase());r&&s.SwapController.setSourceToken(r)}if(n){const r=a.find(l=>l.symbol.toLowerCase()===n.toLowerCase());r&&s.SwapController.setToToken(r)}o&&!isNaN(Number(o))&&s.SwapController.setSourceTokenAmount(o)}onCaipAddressChange({newCaipAddress:o,resetSwapState:i,initializeSwapState:n}){this.caipAddress!==o&&(this.caipAddress=o,i&&s.SwapController.resetState(),n&&s.SwapController.initializeState())}onCaipNetworkChange({newCaipNetwork:o,resetSwapState:i,initializeSwapState:n}){this.caipNetworkId!==(o==null?void 0:o.caipNetworkId)&&(this.caipNetworkId=o==null?void 0:o.caipNetworkId,i&&s.SwapController.resetState(),n&&s.SwapController.initializeState())}};exports.W3mSwapView.styles=E;u([t.n({type:Object})],exports.W3mSwapView.prototype,"initialParams",void 0);u([t.r()],exports.W3mSwapView.prototype,"interval",void 0);u([t.r()],exports.W3mSwapView.prototype,"detailsOpen",void 0);u([t.r()],exports.W3mSwapView.prototype,"caipAddress",void 0);u([t.r()],exports.W3mSwapView.prototype,"caipNetworkId",void 0);u([t.r()],exports.W3mSwapView.prototype,"initialized",void 0);u([t.r()],exports.W3mSwapView.prototype,"loadingQuote",void 0);u([t.r()],exports.W3mSwapView.prototype,"loadingPrices",void 0);u([t.r()],exports.W3mSwapView.prototype,"loadingTransaction",void 0);u([t.r()],exports.W3mSwapView.prototype,"sourceToken",void 0);u([t.r()],exports.W3mSwapView.prototype,"sourceTokenAmount",void 0);u([t.r()],exports.W3mSwapView.prototype,"sourceTokenPriceInUSD",void 0);u([t.r()],exports.W3mSwapView.prototype,"toToken",void 0);u([t.r()],exports.W3mSwapView.prototype,"toTokenAmount",void 0);u([t.r()],exports.W3mSwapView.prototype,"toTokenPriceInUSD",void 0);u([t.r()],exports.W3mSwapView.prototype,"inputError",void 0);u([t.r()],exports.W3mSwapView.prototype,"fetchError",void 0);u([t.r()],exports.W3mSwapView.prototype,"lastTokenPriceUpdate",void 0);exports.W3mSwapView=u([t.customElement("w3m-swap-view")],exports.W3mSwapView);const L=t.css`
514
+ :host > wui-flex:first-child {
515
+ overflow-y: auto;
516
+ overflow-x: hidden;
517
+ scrollbar-width: none;
518
+ }
519
+
520
+ :host > wui-flex:first-child::-webkit-scrollbar {
521
+ display: none;
522
+ }
523
+
524
+ .preview-container,
525
+ .details-container {
526
+ width: 100%;
527
+ }
528
+
529
+ .token-image {
530
+ width: 24px;
531
+ height: 24px;
532
+ box-shadow: 0 0 0 2px ${({tokens:e})=>e.core.glass010};
533
+ border-radius: 12px;
534
+ }
535
+
536
+ wui-loading-hexagon {
537
+ position: absolute;
538
+ }
539
+
540
+ .token-item {
541
+ display: flex;
542
+ align-items: center;
543
+ justify-content: center;
544
+ gap: ${({spacing:e})=>e[2]};
545
+ padding: ${({spacing:e})=>e[2]};
546
+ height: 40px;
547
+ border: none;
548
+ border-radius: 80px;
549
+ background: ${({tokens:e})=>e.theme.foregroundPrimary};
550
+ box-shadow: inset 0 0 0 1px ${({tokens:e})=>e.theme.foregroundPrimary};
551
+ cursor: pointer;
552
+ transition: background ${({durations:e})=>e.lg}
553
+ ${({easings:e})=>e["ease-out-power-2"]};
554
+ will-change: background;
555
+ }
556
+
557
+ .token-item:hover {
558
+ background: ${({tokens:e})=>e.core.glass010};
559
+ }
560
+
561
+ .preview-token-details-container {
562
+ width: 100%;
563
+ }
564
+
565
+ .details-row {
566
+ width: 100%;
567
+ padding: ${({spacing:e})=>e[3]} ${({spacing:e})=>e[5]};
568
+ border-radius: ${({borderRadius:e})=>e[3]};
569
+ background: ${({tokens:e})=>e.theme.foregroundPrimary};
570
+ }
571
+
572
+ .action-buttons-container {
573
+ width: 100%;
574
+ gap: ${({spacing:e})=>e[2]};
575
+ }
576
+
577
+ .action-buttons-container > button {
578
+ display: flex;
579
+ align-items: center;
580
+ justify-content: center;
581
+ background: transparent;
582
+ height: 48px;
583
+ border-radius: ${({borderRadius:e})=>e[4]};
584
+ border: none;
585
+ box-shadow: inset 0 0 0 1px ${({tokens:e})=>e.core.glass010};
586
+ }
587
+
588
+ .action-buttons-container > button:disabled {
589
+ opacity: 0.8;
590
+ cursor: not-allowed;
591
+ }
592
+
593
+ .action-button > wui-loading-spinner {
594
+ display: inline-block;
595
+ }
596
+
597
+ .cancel-button:hover,
598
+ .action-button:hover {
599
+ cursor: pointer;
600
+ }
601
+
602
+ .action-buttons-container > wui-button.cancel-button {
603
+ flex: 2;
604
+ }
605
+
606
+ .action-buttons-container > wui-button.action-button {
607
+ flex: 4;
608
+ }
609
+
610
+ .action-buttons-container > button.action-button > wui-text {
611
+ color: white;
612
+ }
613
+
614
+ .details-container > wui-flex {
615
+ background: ${({tokens:e})=>e.theme.foregroundPrimary};
616
+ border-radius: ${({borderRadius:e})=>e[3]};
617
+ width: 100%;
618
+ }
619
+
620
+ .details-container > wui-flex > button {
621
+ border: none;
622
+ background: none;
623
+ padding: ${({spacing:e})=>e[3]};
624
+ border-radius: ${({borderRadius:e})=>e[3]};
625
+ transition: background ${({durations:e})=>e.lg}
626
+ ${({easings:e})=>e["ease-out-power-2"]};
627
+ will-change: background;
628
+ }
629
+
630
+ .details-container > wui-flex > button:hover {
631
+ background: ${({tokens:e})=>e.theme.foregroundPrimary};
632
+ }
633
+
634
+ .details-content-container {
635
+ padding: ${({spacing:e})=>e[2]};
636
+ display: flex;
637
+ align-items: center;
638
+ justify-content: center;
639
+ }
640
+
641
+ .details-content-container > wui-flex {
642
+ width: 100%;
643
+ }
644
+
645
+ .details-row {
646
+ width: 100%;
647
+ padding: ${({spacing:e})=>e[3]} ${({spacing:e})=>e[5]};
648
+ border-radius: ${({borderRadius:e})=>e[3]};
649
+ background: ${({tokens:e})=>e.theme.foregroundPrimary};
650
+ }
651
+ `;var p=function(e,o,i,n){var a=arguments.length,r=a<3?o:n===null?n=Object.getOwnPropertyDescriptor(o,i):n,l;if(typeof Reflect=="object"&&typeof Reflect.decorate=="function")r=Reflect.decorate(e,o,i,n);else for(var c=e.length-1;c>=0;c--)(l=e[c])&&(r=(a<3?l(r):a>3?l(o,i,r):l(o,i))||r);return a>3&&r&&Object.defineProperty(o,i,r),r};exports.W3mSwapPreviewView=class extends t.i{constructor(){var o;super(),this.unsubscribe=[],this.detailsOpen=!0,this.approvalTransaction=s.SwapController.state.approvalTransaction,this.swapTransaction=s.SwapController.state.swapTransaction,this.sourceToken=s.SwapController.state.sourceToken,this.sourceTokenAmount=s.SwapController.state.sourceTokenAmount??"",this.sourceTokenPriceInUSD=s.SwapController.state.sourceTokenPriceInUSD,this.balanceSymbol=(o=t.ChainController.getAccountData())==null?void 0:o.balanceSymbol,this.toToken=s.SwapController.state.toToken,this.toTokenAmount=s.SwapController.state.toTokenAmount??"",this.toTokenPriceInUSD=s.SwapController.state.toTokenPriceInUSD,this.caipNetwork=t.ChainController.state.activeCaipNetwork,this.inputError=s.SwapController.state.inputError,this.loadingQuote=s.SwapController.state.loadingQuote,this.loadingApprovalTransaction=s.SwapController.state.loadingApprovalTransaction,this.loadingBuildTransaction=s.SwapController.state.loadingBuildTransaction,this.loadingTransaction=s.SwapController.state.loadingTransaction,this.unsubscribe.push(t.ChainController.subscribeChainProp("accountState",i=>{(i==null?void 0:i.balanceSymbol)!==this.balanceSymbol&&t.RouterController.goBack()}),t.ChainController.subscribeKey("activeCaipNetwork",i=>{this.caipNetwork!==i&&(this.caipNetwork=i)}),s.SwapController.subscribe(i=>{this.approvalTransaction=i.approvalTransaction,this.swapTransaction=i.swapTransaction,this.sourceToken=i.sourceToken,this.toToken=i.toToken,this.toTokenPriceInUSD=i.toTokenPriceInUSD,this.sourceTokenAmount=i.sourceTokenAmount??"",this.toTokenAmount=i.toTokenAmount??"",this.inputError=i.inputError,i.inputError&&t.RouterController.goBack(),this.loadingQuote=i.loadingQuote,this.loadingApprovalTransaction=i.loadingApprovalTransaction,this.loadingBuildTransaction=i.loadingBuildTransaction,this.loadingTransaction=i.loadingTransaction}))}firstUpdated(){s.SwapController.getTransaction(),this.refreshTransaction()}disconnectedCallback(){this.unsubscribe.forEach(o=>o==null?void 0:o()),clearInterval(this.interval)}render(){return t.b`
652
+ <wui-flex flexDirection="column" .padding=${["0","4","4","4"]} gap="3">
653
+ ${this.templateSwap()}
654
+ </wui-flex>
655
+ `}refreshTransaction(){this.interval=setInterval(()=>{s.SwapController.getApprovalLoadingState()||s.SwapController.getTransaction()},1e4)}templateSwap(){var h,k,y,T;const o=`${t.NumberUtil.formatNumberToLocalString(parseFloat(this.sourceTokenAmount))} ${(h=this.sourceToken)==null?void 0:h.symbol}`,i=`${t.NumberUtil.formatNumberToLocalString(parseFloat(this.toTokenAmount))} ${(k=this.toToken)==null?void 0:k.symbol}`,n=parseFloat(this.sourceTokenAmount)*this.sourceTokenPriceInUSD,a=parseFloat(this.toTokenAmount)*this.toTokenPriceInUSD,r=t.NumberUtil.formatNumberToLocalString(n),l=t.NumberUtil.formatNumberToLocalString(a),c=this.loadingQuote||this.loadingBuildTransaction||this.loadingTransaction||this.loadingApprovalTransaction;return t.b`
656
+ <wui-flex flexDirection="column" alignItems="center" gap="4">
657
+ <wui-flex class="preview-container" flexDirection="column" alignItems="flex-start" gap="4">
658
+ <wui-flex
659
+ class="preview-token-details-container"
660
+ alignItems="center"
661
+ justifyContent="space-between"
662
+ gap="4"
663
+ >
664
+ <wui-flex flexDirection="column" alignItems="flex-start" gap="01">
665
+ <wui-text variant="sm-regular" color="secondary">Send</wui-text>
666
+ <wui-text variant="md-regular" color="primary">$${r}</wui-text>
667
+ </wui-flex>
668
+ <wui-token-button
669
+ flexDirection="row-reverse"
670
+ text=${o}
671
+ imageSrc=${(y=this.sourceToken)==null?void 0:y.logoUri}
672
+ >
673
+ </wui-token-button>
674
+ </wui-flex>
675
+ <wui-icon name="recycleHorizontal" color="default" size="md"></wui-icon>
676
+ <wui-flex
677
+ class="preview-token-details-container"
678
+ alignItems="center"
679
+ justifyContent="space-between"
680
+ gap="4"
681
+ >
682
+ <wui-flex flexDirection="column" alignItems="flex-start" gap="01">
683
+ <wui-text variant="sm-regular" color="secondary">Receive</wui-text>
684
+ <wui-text variant="md-regular" color="primary">$${l}</wui-text>
685
+ </wui-flex>
686
+ <wui-token-button
687
+ flexDirection="row-reverse"
688
+ text=${i}
689
+ imageSrc=${(T=this.toToken)==null?void 0:T.logoUri}
690
+ >
691
+ </wui-token-button>
692
+ </wui-flex>
693
+ </wui-flex>
694
+
695
+ ${this.templateDetails()}
696
+
697
+ <wui-flex flexDirection="row" alignItems="center" justifyContent="center" gap="2">
698
+ <wui-icon size="sm" color="default" name="info"></wui-icon>
699
+ <wui-text variant="sm-regular" color="secondary">Review transaction carefully</wui-text>
700
+ </wui-flex>
701
+
702
+ <wui-flex
703
+ class="action-buttons-container"
704
+ flexDirection="row"
705
+ alignItems="center"
706
+ justifyContent="space-between"
707
+ gap="2"
708
+ >
709
+ <wui-button
710
+ class="cancel-button"
711
+ fullWidth
712
+ size="lg"
713
+ borderRadius="xs"
714
+ variant="neutral-secondary"
715
+ @click=${this.onCancelTransaction.bind(this)}
716
+ >
717
+ <wui-text variant="md-medium" color="secondary">Cancel</wui-text>
718
+ </wui-button>
719
+ <wui-button
720
+ class="action-button"
721
+ fullWidth
722
+ size="lg"
723
+ borderRadius="xs"
724
+ variant="accent-primary"
725
+ ?loading=${c}
726
+ ?disabled=${c}
727
+ @click=${this.onSendTransaction.bind(this)}
728
+ >
729
+ <wui-text variant="md-medium" color="invert"> ${this.actionButtonLabel()} </wui-text>
730
+ </wui-button>
731
+ </wui-flex>
732
+ </wui-flex>
733
+ `}templateDetails(){return!this.sourceToken||!this.toToken||this.inputError?null:t.b`<w3m-swap-details .detailsOpen=${this.detailsOpen}></w3m-swap-details>`}actionButtonLabel(){return this.loadingApprovalTransaction?"Approving...":this.approvalTransaction?"Approve":"Swap"}onCancelTransaction(){t.RouterController.goBack()}onSendTransaction(){this.approvalTransaction?s.SwapController.sendTransactionForApproval(this.approvalTransaction):s.SwapController.sendTransactionForSwap(this.swapTransaction)}};exports.W3mSwapPreviewView.styles=L;p([t.r()],exports.W3mSwapPreviewView.prototype,"interval",void 0);p([t.r()],exports.W3mSwapPreviewView.prototype,"detailsOpen",void 0);p([t.r()],exports.W3mSwapPreviewView.prototype,"approvalTransaction",void 0);p([t.r()],exports.W3mSwapPreviewView.prototype,"swapTransaction",void 0);p([t.r()],exports.W3mSwapPreviewView.prototype,"sourceToken",void 0);p([t.r()],exports.W3mSwapPreviewView.prototype,"sourceTokenAmount",void 0);p([t.r()],exports.W3mSwapPreviewView.prototype,"sourceTokenPriceInUSD",void 0);p([t.r()],exports.W3mSwapPreviewView.prototype,"balanceSymbol",void 0);p([t.r()],exports.W3mSwapPreviewView.prototype,"toToken",void 0);p([t.r()],exports.W3mSwapPreviewView.prototype,"toTokenAmount",void 0);p([t.r()],exports.W3mSwapPreviewView.prototype,"toTokenPriceInUSD",void 0);p([t.r()],exports.W3mSwapPreviewView.prototype,"caipNetwork",void 0);p([t.r()],exports.W3mSwapPreviewView.prototype,"inputError",void 0);p([t.r()],exports.W3mSwapPreviewView.prototype,"loadingQuote",void 0);p([t.r()],exports.W3mSwapPreviewView.prototype,"loadingApprovalTransaction",void 0);p([t.r()],exports.W3mSwapPreviewView.prototype,"loadingBuildTransaction",void 0);p([t.r()],exports.W3mSwapPreviewView.prototype,"loadingTransaction",void 0);exports.W3mSwapPreviewView=p([t.customElement("w3m-swap-preview-view")],exports.W3mSwapPreviewView);const N=t.css`
734
+ :host {
735
+ width: 100%;
736
+ height: 60px;
737
+ min-height: 60px;
738
+ }
739
+
740
+ :host > wui-flex {
741
+ cursor: pointer;
742
+ height: 100%;
743
+ display: flex;
744
+ column-gap: ${({spacing:e})=>e[3]};
745
+ padding: ${({spacing:e})=>e[2]};
746
+ padding-right: ${({spacing:e})=>e[4]};
747
+ width: 100%;
748
+ background-color: transparent;
749
+ border-radius: ${({borderRadius:e})=>e[4]};
750
+ color: ${({tokens:e})=>e.theme.foregroundSecondary};
751
+ transition:
752
+ background-color ${({durations:e})=>e.lg}
753
+ ${({easings:e})=>e["ease-out-power-2"]},
754
+ opacity ${({durations:e})=>e.lg} ${({easings:e})=>e["ease-out-power-2"]};
755
+ will-change: background-color, opacity;
756
+ }
757
+
758
+ @media (hover: hover) and (pointer: fine) {
759
+ :host > wui-flex:hover {
760
+ background-color: ${({tokens:e})=>e.theme.foregroundPrimary};
761
+ }
762
+
763
+ :host > wui-flex:active {
764
+ background-color: ${({tokens:e})=>e.core.glass010};
765
+ }
766
+ }
767
+
768
+ :host([disabled]) > wui-flex {
769
+ opacity: 0.6;
770
+ }
771
+
772
+ :host([disabled]) > wui-flex:hover {
773
+ background-color: transparent;
774
+ }
775
+
776
+ :host > wui-flex > wui-flex {
777
+ flex: 1;
778
+ }
779
+
780
+ :host > wui-flex > wui-image,
781
+ :host > wui-flex > .token-item-image-placeholder {
782
+ width: 40px;
783
+ max-width: 40px;
784
+ height: 40px;
785
+ border-radius: ${({borderRadius:e})=>e[20]};
786
+ position: relative;
787
+ }
788
+
789
+ :host > wui-flex > .token-item-image-placeholder {
790
+ display: flex;
791
+ align-items: center;
792
+ justify-content: center;
793
+ }
794
+
795
+ :host > wui-flex > wui-image::after,
796
+ :host > wui-flex > .token-item-image-placeholder::after {
797
+ position: absolute;
798
+ content: '';
799
+ inset: 0;
800
+ box-shadow: inset 0 0 0 1px ${({tokens:e})=>e.core.glass010};
801
+ border-radius: ${({borderRadius:e})=>e[8]};
802
+ }
803
+
804
+ button > wui-icon-box[data-variant='square-blue'] {
805
+ border-radius: ${({borderRadius:e})=>e[2]};
806
+ position: relative;
807
+ border: none;
808
+ width: 36px;
809
+ height: 36px;
810
+ }
811
+ `;var x=function(e,o,i,n){var a=arguments.length,r=a<3?o:n===null?n=Object.getOwnPropertyDescriptor(o,i):n,l;if(typeof Reflect=="object"&&typeof Reflect.decorate=="function")r=Reflect.decorate(e,o,i,n);else for(var c=e.length-1;c>=0;c--)(l=e[c])&&(r=(a<3?l(r):a>3?l(o,i,r):l(o,i))||r);return a>3&&r&&Object.defineProperty(o,i,r),r};let b=class extends t.i{constructor(){super(),this.observer=new IntersectionObserver(()=>{}),this.imageSrc=void 0,this.name=void 0,this.symbol=void 0,this.price=void 0,this.amount=void 0,this.visible=!1,this.imageError=!1,this.observer=new IntersectionObserver(o=>{o.forEach(i=>{i.isIntersecting?this.visible=!0:this.visible=!1})},{threshold:.1})}firstUpdated(){this.observer.observe(this)}disconnectedCallback(){this.observer.disconnect()}render(){var i;if(!this.visible)return null;const o=this.amount&&this.price?(i=t.NumberUtil.multiply(this.price,this.amount))==null?void 0:i.toFixed(3):null;return t.b`
812
+ <wui-flex alignItems="center">
813
+ ${this.visualTemplate()}
814
+ <wui-flex flexDirection="column" gap="1">
815
+ <wui-flex justifyContent="space-between">
816
+ <wui-text variant="md-medium" color="primary" lineClamp="1">${this.name}</wui-text>
817
+ ${o?t.b`
818
+ <wui-text variant="md-medium" color="primary">
819
+ $${t.NumberUtil.formatNumberToLocalString(o,3)}
820
+ </wui-text>
821
+ `:null}
822
+ </wui-flex>
823
+ <wui-flex justifyContent="space-between">
824
+ <wui-text variant="sm-regular" color="secondary" lineClamp="1">${this.symbol}</wui-text>
825
+ ${this.amount?t.b`<wui-text variant="sm-regular" color="secondary">
826
+ ${t.NumberUtil.formatNumberToLocalString(this.amount,5)}
827
+ </wui-text>`:null}
828
+ </wui-flex>
829
+ </wui-flex>
830
+ </wui-flex>
831
+ `}visualTemplate(){return this.imageError?t.b`<wui-flex class="token-item-image-placeholder">
832
+ <wui-icon name="image" color="inherit"></wui-icon>
833
+ </wui-flex>`:this.imageSrc?t.b`<wui-image
834
+ width="40"
835
+ height="40"
836
+ src=${this.imageSrc}
837
+ @onLoadError=${this.imageLoadError}
838
+ ></wui-image>`:null}imageLoadError(){this.imageError=!0}};b.styles=[t.resetStyles,t.elementStyles,N];x([t.n()],b.prototype,"imageSrc",void 0);x([t.n()],b.prototype,"name",void 0);x([t.n()],b.prototype,"symbol",void 0);x([t.n()],b.prototype,"price",void 0);x([t.n()],b.prototype,"amount",void 0);x([t.r()],b.prototype,"visible",void 0);x([t.r()],b.prototype,"imageError",void 0);b=x([t.customElement("wui-token-list-item")],b);const R=t.css`
839
+ :host {
840
+ width: 100%;
841
+ }
842
+
843
+ :host > wui-flex {
844
+ cursor: pointer;
845
+ height: 100%;
846
+ width: 100%;
847
+ display: flex;
848
+ column-gap: ${({spacing:e})=>e[3]};
849
+ padding: ${({spacing:e})=>e[2]};
850
+ padding-right: ${({spacing:e})=>e[4]};
851
+ }
852
+
853
+ wui-flex {
854
+ display: flex;
855
+ flex: 1;
856
+ }
857
+ `;var _=function(e,o,i,n){var a=arguments.length,r=a<3?o:n===null?n=Object.getOwnPropertyDescriptor(o,i):n,l;if(typeof Reflect=="object"&&typeof Reflect.decorate=="function")r=Reflect.decorate(e,o,i,n);else for(var c=e.length-1;c>=0;c--)(l=e[c])&&(r=(a<3?l(r):a>3?l(o,i,r):l(o,i))||r);return a>3&&r&&Object.defineProperty(o,i,r),r};let $=class extends t.i{render(){return t.b`
858
+ <wui-flex alignItems="center">
859
+ <wui-shimmer width="40px" height="40px"></wui-shimmer>
860
+ <wui-flex flexDirection="column" gap="1">
861
+ <wui-shimmer width="72px" height="16px" borderRadius="4xs"></wui-shimmer>
862
+ <wui-shimmer width="148px" height="14px" borderRadius="4xs"></wui-shimmer>
863
+ </wui-flex>
864
+ <wui-flex flexDirection="column" gap="1" alignItems="flex-end">
865
+ <wui-shimmer width="24px" height="12px" borderRadius="4xs"></wui-shimmer>
866
+ <wui-shimmer width="32px" height="12px" borderRadius="4xs"></wui-shimmer>
867
+ </wui-flex>
868
+ </wui-flex>
869
+ `}};$.styles=[t.resetStyles,R];$=_([t.customElement("wui-token-list-item-loader")],$);const j=t.css`
870
+ :host {
871
+ --tokens-scroll--top-opacity: 0;
872
+ --tokens-scroll--bottom-opacity: 1;
873
+ --suggested-tokens-scroll--left-opacity: 0;
874
+ --suggested-tokens-scroll--right-opacity: 1;
875
+ }
876
+
877
+ :host > wui-flex:first-child {
878
+ overflow-y: hidden;
879
+ overflow-x: hidden;
880
+ scrollbar-width: none;
881
+ scrollbar-height: none;
882
+ }
883
+
884
+ :host > wui-flex:first-child::-webkit-scrollbar {
885
+ display: none;
886
+ }
887
+
888
+ wui-loading-hexagon {
889
+ position: absolute;
890
+ }
891
+
892
+ .suggested-tokens-container {
893
+ overflow-x: auto;
894
+ mask-image: linear-gradient(
895
+ to right,
896
+ rgba(0, 0, 0, calc(1 - var(--suggested-tokens-scroll--left-opacity))) 0px,
897
+ rgba(200, 200, 200, calc(1 - var(--suggested-tokens-scroll--left-opacity))) 1px,
898
+ black 50px,
899
+ black 90px,
900
+ black calc(100% - 90px),
901
+ black calc(100% - 50px),
902
+ rgba(155, 155, 155, calc(1 - var(--suggested-tokens-scroll--right-opacity))) calc(100% - 1px),
903
+ rgba(0, 0, 0, calc(1 - var(--suggested-tokens-scroll--right-opacity))) 100%
904
+ );
905
+ }
906
+
907
+ .suggested-tokens-container::-webkit-scrollbar {
908
+ display: none;
909
+ }
910
+
911
+ .tokens-container {
912
+ border-top: 1px solid ${({tokens:e})=>e.core.glass010};
913
+ height: 100%;
914
+ max-height: 390px;
915
+ }
916
+
917
+ .tokens {
918
+ width: 100%;
919
+ overflow-y: auto;
920
+ mask-image: linear-gradient(
921
+ to bottom,
922
+ rgba(0, 0, 0, calc(1 - var(--tokens-scroll--top-opacity))) 0px,
923
+ rgba(200, 200, 200, calc(1 - var(--tokens-scroll--top-opacity))) 1px,
924
+ black 50px,
925
+ black 90px,
926
+ black calc(100% - 90px),
927
+ black calc(100% - 50px),
928
+ rgba(155, 155, 155, calc(1 - var(--tokens-scroll--bottom-opacity))) calc(100% - 1px),
929
+ rgba(0, 0, 0, calc(1 - var(--tokens-scroll--bottom-opacity))) 100%
930
+ );
931
+ }
932
+
933
+ .network-search-input,
934
+ .select-network-button {
935
+ height: 40px;
936
+ }
937
+
938
+ .select-network-button {
939
+ border: none;
940
+ display: flex;
941
+ flex-direction: row;
942
+ align-items: center;
943
+ justify-content: center;
944
+ gap: ${({spacing:e})=>e[2]};
945
+ box-shadow: inset 0 0 0 1px ${({tokens:e})=>e.core.glass010};
946
+ background-color: transparent;
947
+ border-radius: ${({borderRadius:e})=>e[3]};
948
+ padding: ${({spacing:e})=>e[2]};
949
+ align-items: center;
950
+ transition: background-color ${({durations:e})=>e.lg}
951
+ ${({easings:e})=>e["ease-out-power-2"]};
952
+ will-change: background-color;
953
+ }
954
+
955
+ .select-network-button:hover {
956
+ background-color: ${({tokens:e})=>e.theme.foregroundPrimary};
957
+ }
958
+
959
+ .select-network-button > wui-image {
960
+ width: 26px;
961
+ height: 26px;
962
+ border-radius: ${({borderRadius:e})=>e[4]};
963
+ box-shadow: inset 0 0 0 1px ${({tokens:e})=>e.core.glass010};
964
+ }
965
+ `;var g=function(e,o,i,n){var a=arguments.length,r=a<3?o:n===null?n=Object.getOwnPropertyDescriptor(o,i):n,l;if(typeof Reflect=="object"&&typeof Reflect.decorate=="function")r=Reflect.decorate(e,o,i,n);else for(var c=e.length-1;c>=0;c--)(l=e[c])&&(r=(a<3?l(r):a>3?l(o,i,r):l(o,i))||r);return a>3&&r&&Object.defineProperty(o,i,r),r};exports.W3mSwapSelectTokenView=class extends t.i{constructor(){var o;super(),this.unsubscribe=[],this.targetToken=(o=t.RouterController.state.data)==null?void 0:o.target,this.sourceToken=s.SwapController.state.sourceToken,this.sourceTokenAmount=s.SwapController.state.sourceTokenAmount,this.toToken=s.SwapController.state.toToken,this.myTokensWithBalance=s.SwapController.state.myTokensWithBalance,this.popularTokens=s.SwapController.state.popularTokens,this.suggestedTokens=s.SwapController.state.suggestedTokens,this.tokensLoading=s.SwapController.state.tokensLoading,this.searchValue="",this.unsubscribe.push(s.SwapController.subscribe(i=>{this.sourceToken=i.sourceToken,this.toToken=i.toToken,this.myTokensWithBalance=i.myTokensWithBalance,this.popularTokens=i.popularTokens,this.suggestedTokens=i.suggestedTokens,this.tokensLoading=i.tokensLoading}))}async firstUpdated(){await s.SwapController.getTokenList()}updated(){var n,a;const o=(n=this.renderRoot)==null?void 0:n.querySelector(".suggested-tokens-container");o==null||o.addEventListener("scroll",this.handleSuggestedTokensScroll.bind(this));const i=(a=this.renderRoot)==null?void 0:a.querySelector(".tokens");i==null||i.addEventListener("scroll",this.handleTokenListScroll.bind(this))}disconnectedCallback(){var n,a;super.disconnectedCallback();const o=(n=this.renderRoot)==null?void 0:n.querySelector(".suggested-tokens-container"),i=(a=this.renderRoot)==null?void 0:a.querySelector(".tokens");o==null||o.removeEventListener("scroll",this.handleSuggestedTokensScroll.bind(this)),i==null||i.removeEventListener("scroll",this.handleTokenListScroll.bind(this)),clearInterval(this.interval)}render(){return t.b`
966
+ <wui-flex flexDirection="column" gap="3">
967
+ ${this.templateSearchInput()} ${this.templateSuggestedTokens()} ${this.templateTokens()}
968
+ </wui-flex>
969
+ `}onSelectToken(o){this.targetToken==="sourceToken"?s.SwapController.setSourceToken(o):(s.SwapController.setToToken(o),this.sourceToken&&this.sourceTokenAmount&&s.SwapController.swapTokens()),t.RouterController.goBack()}templateSearchInput(){return t.b`
970
+ <wui-flex .padding=${["1","3","0","3"]} gap="2">
971
+ <wui-input-text
972
+ data-testid="swap-select-token-search-input"
973
+ class="network-search-input"
974
+ size="sm"
975
+ placeholder="Search token"
976
+ icon="search"
977
+ .value=${this.searchValue}
978
+ @inputChange=${this.onSearchInputChange.bind(this)}
979
+ ></wui-input-text>
980
+ </wui-flex>
981
+ `}templateMyTokens(){const o=this.myTokensWithBalance?Object.values(this.myTokensWithBalance):[],i=this.filterTokensWithText(o,this.searchValue);return(i==null?void 0:i.length)>0?t.b`<wui-flex justifyContent="flex-start" padding="2">
982
+ <wui-text variant="md-medium" color="secondary">Your tokens</wui-text>
983
+ </wui-flex>
984
+ ${i.map(n=>{var r,l,c;const a=n.symbol===((r=this.sourceToken)==null?void 0:r.symbol)||n.symbol===((l=this.toToken)==null?void 0:l.symbol);return t.b`
985
+ <wui-token-list-item
986
+ data-testid="swap-select-token-item-${n.symbol}"
987
+ name=${n.name}
988
+ ?disabled=${a}
989
+ symbol=${n.symbol}
990
+ price=${n==null?void 0:n.price}
991
+ amount=${(c=n==null?void 0:n.quantity)==null?void 0:c.numeric}
992
+ imageSrc=${n.logoUri}
993
+ @click=${()=>{a||this.onSelectToken(n)}}
994
+ >
995
+ </wui-token-list-item>
996
+ `})}`:null}templateAllTokens(){const o=this.popularTokens?this.popularTokens:[],i=this.filterTokensWithText(o,this.searchValue);return this.tokensLoading?t.b`
997
+ <wui-token-list-item-loader></wui-token-list-item-loader>
998
+ <wui-token-list-item-loader></wui-token-list-item-loader>
999
+ <wui-token-list-item-loader></wui-token-list-item-loader>
1000
+ <wui-token-list-item-loader></wui-token-list-item-loader>
1001
+ <wui-token-list-item-loader></wui-token-list-item-loader>
1002
+ `:(i==null?void 0:i.length)>0?t.b`
1003
+ ${i.map(n=>t.b`
1004
+ <wui-token-list-item
1005
+ data-testid="swap-select-token-item-${n.symbol}"
1006
+ name=${n.name}
1007
+ symbol=${n.symbol}
1008
+ imageSrc=${n.logoUri}
1009
+ @click=${()=>this.onSelectToken(n)}
1010
+ >
1011
+ </wui-token-list-item>
1012
+ `)}
1013
+ `:null}templateTokens(){return t.b`
1014
+ <wui-flex class="tokens-container">
1015
+ <wui-flex class="tokens" .padding=${["0","2","2","2"]} flexDirection="column">
1016
+ ${this.templateMyTokens()}
1017
+ <wui-flex justifyContent="flex-start" padding="3">
1018
+ <wui-text variant="md-medium" color="secondary">Tokens</wui-text>
1019
+ </wui-flex>
1020
+ ${this.templateAllTokens()}
1021
+ </wui-flex>
1022
+ </wui-flex>
1023
+ `}templateSuggestedTokens(){const o=this.suggestedTokens?this.suggestedTokens.slice(0,8):null;return this.tokensLoading?t.b`
1024
+ <wui-flex
1025
+ class="suggested-tokens-container"
1026
+ .padding=${["0","3","0","3"]}
1027
+ gap="2"
1028
+ >
1029
+ <wui-token-button loading></wui-token-button>
1030
+ <wui-token-button loading></wui-token-button>
1031
+ <wui-token-button loading></wui-token-button>
1032
+ <wui-token-button loading></wui-token-button>
1033
+ <wui-token-button loading></wui-token-button>
1034
+ </wui-flex>
1035
+ `:o?t.b`
1036
+ <wui-flex
1037
+ class="suggested-tokens-container"
1038
+ .padding=${["0","3","0","3"]}
1039
+ gap="2"
1040
+ >
1041
+ ${o.map(i=>t.b`
1042
+ <wui-token-button
1043
+ text=${i.symbol}
1044
+ imageSrc=${i.logoUri}
1045
+ @click=${()=>this.onSelectToken(i)}
1046
+ >
1047
+ </wui-token-button>
1048
+ `)}
1049
+ </wui-flex>
1050
+ `:null}onSearchInputChange(o){this.searchValue=o.detail}handleSuggestedTokensScroll(){var i;const o=(i=this.renderRoot)==null?void 0:i.querySelector(".suggested-tokens-container");o&&(o.style.setProperty("--suggested-tokens-scroll--left-opacity",t.MathUtil.interpolate([0,100],[0,1],o.scrollLeft).toString()),o.style.setProperty("--suggested-tokens-scroll--right-opacity",t.MathUtil.interpolate([0,100],[0,1],o.scrollWidth-o.scrollLeft-o.offsetWidth).toString()))}handleTokenListScroll(){var i;const o=(i=this.renderRoot)==null?void 0:i.querySelector(".tokens");o&&(o.style.setProperty("--tokens-scroll--top-opacity",t.MathUtil.interpolate([0,100],[0,1],o.scrollTop).toString()),o.style.setProperty("--tokens-scroll--bottom-opacity",t.MathUtil.interpolate([0,100],[0,1],o.scrollHeight-o.scrollTop-o.offsetHeight).toString()))}filterTokensWithText(o,i){return o.filter(n=>`${n.symbol} ${n.name} ${n.address}`.toLowerCase().includes(i.toLowerCase())).sort((n,a)=>{const r=`${n.symbol} ${n.name} ${n.address}`.toLowerCase(),l=`${a.symbol} ${a.name} ${a.address}`.toLowerCase(),c=r.indexOf(i.toLowerCase()),h=l.indexOf(i.toLowerCase());return c-h})}};exports.W3mSwapSelectTokenView.styles=j;g([t.r()],exports.W3mSwapSelectTokenView.prototype,"interval",void 0);g([t.r()],exports.W3mSwapSelectTokenView.prototype,"targetToken",void 0);g([t.r()],exports.W3mSwapSelectTokenView.prototype,"sourceToken",void 0);g([t.r()],exports.W3mSwapSelectTokenView.prototype,"sourceTokenAmount",void 0);g([t.r()],exports.W3mSwapSelectTokenView.prototype,"toToken",void 0);g([t.r()],exports.W3mSwapSelectTokenView.prototype,"myTokensWithBalance",void 0);g([t.r()],exports.W3mSwapSelectTokenView.prototype,"popularTokens",void 0);g([t.r()],exports.W3mSwapSelectTokenView.prototype,"suggestedTokens",void 0);g([t.r()],exports.W3mSwapSelectTokenView.prototype,"tokensLoading",void 0);g([t.r()],exports.W3mSwapSelectTokenView.prototype,"searchValue",void 0);exports.W3mSwapSelectTokenView=g([t.customElement("w3m-swap-select-token-view")],exports.W3mSwapSelectTokenView);