@hsuite/native-connect-angular 1.0.0

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 (276) hide show
  1. package/README.md +48 -0
  2. package/USAGE_EXAMPLES.md +476 -0
  3. package/assets/wallets/extension.svg +7 -0
  4. package/assets/wallets/hashpack.svg +6 -0
  5. package/assets/wallets/hsuite.svg +11 -0
  6. package/assets/wallets/kabila.svg +11 -0
  7. package/assets/wallets/walletconnect.svg +13 -0
  8. package/coverage/base.css +224 -0
  9. package/coverage/block-navigation.js +87 -0
  10. package/coverage/coverage-summary.json +50 -0
  11. package/coverage/favicon.png +0 -0
  12. package/coverage/index.html +476 -0
  13. package/coverage/lcov-report/base.css +224 -0
  14. package/coverage/lcov-report/block-navigation.js +87 -0
  15. package/coverage/lcov-report/favicon.png +0 -0
  16. package/coverage/lcov-report/index.html +476 -0
  17. package/coverage/lcov-report/lib/components/account-selector/account-actions/account-actions.component.ts.html +868 -0
  18. package/coverage/lcov-report/lib/components/account-selector/account-actions/index.html +116 -0
  19. package/coverage/lcov-report/lib/components/account-selector/account-filter/account-filter.component.ts.html +1288 -0
  20. package/coverage/lcov-report/lib/components/account-selector/account-filter/index.html +116 -0
  21. package/coverage/lcov-report/lib/components/account-selector/account-formatting.service.ts.html +685 -0
  22. package/coverage/lcov-report/lib/components/account-selector/account-grouping.service.ts.html +766 -0
  23. package/coverage/lcov-report/lib/components/account-selector/account-list/account-list.component.ts.html +1495 -0
  24. package/coverage/lcov-report/lib/components/account-selector/account-list/index.html +116 -0
  25. package/coverage/lcov-report/lib/components/account-selector/account-selector.component.ts.html +1495 -0
  26. package/coverage/lcov-report/lib/components/account-selector/account-selector.service.ts.html +1588 -0
  27. package/coverage/lcov-report/lib/components/account-selector/index.html +161 -0
  28. package/coverage/lcov-report/lib/components/wallet-account-display/index.html +116 -0
  29. package/coverage/lcov-report/lib/components/wallet-account-display/wallet-account-display.component.ts.html +505 -0
  30. package/coverage/lcov-report/lib/components/wallet-connect-button/index.html +116 -0
  31. package/coverage/lcov-report/lib/components/wallet-connect-button/wallet-connect-button.component.ts.html +805 -0
  32. package/coverage/lcov-report/lib/components/wallet-connect-prompt/index.html +116 -0
  33. package/coverage/lcov-report/lib/components/wallet-connect-prompt/wallet-connect-prompt.component.ts.html +409 -0
  34. package/coverage/lcov-report/lib/components/wallet-connected-guard/index.html +116 -0
  35. package/coverage/lcov-report/lib/components/wallet-connected-guard/wallet-connected-guard.component.ts.html +304 -0
  36. package/coverage/lcov-report/lib/components/wallet-connection-modal/connection-method-step/connection-method-step.component.ts.html +436 -0
  37. package/coverage/lcov-report/lib/components/wallet-connection-modal/connection-method-step/index.html +116 -0
  38. package/coverage/lcov-report/lib/components/wallet-connection-modal/index.html +116 -0
  39. package/coverage/lcov-report/lib/components/wallet-connection-modal/qr-pairing-step/index.html +116 -0
  40. package/coverage/lcov-report/lib/components/wallet-connection-modal/qr-pairing-step/qr-pairing-step.component.ts.html +2287 -0
  41. package/coverage/lcov-report/lib/components/wallet-connection-modal/wallet-connection-modal.component.ts.html +2275 -0
  42. package/coverage/lcov-report/lib/components/wallet-session-display/index.html +116 -0
  43. package/coverage/lcov-report/lib/components/wallet-session-display/wallet-session-display.component.ts.html +676 -0
  44. package/coverage/lcov-report/lib/components/wallet-transaction-status/index.html +116 -0
  45. package/coverage/lcov-report/lib/components/wallet-transaction-status/wallet-transaction-status.component.ts.html +703 -0
  46. package/coverage/lcov-report/lib/directives/index.html +146 -0
  47. package/coverage/lcov-report/lib/directives/wallet-connected.directive.ts.html +670 -0
  48. package/coverage/lcov-report/lib/directives/wallet-context.directive.ts.html +547 -0
  49. package/coverage/lcov-report/lib/directives/wallet-events.directive.ts.html +781 -0
  50. package/coverage/lcov-report/lib/hsuite-wallet.module.ts.html +715 -0
  51. package/coverage/lcov-report/lib/index.html +116 -0
  52. package/coverage/lcov-report/lib/models/connection-config.model.ts.html +280 -0
  53. package/coverage/lcov-report/lib/models/index.html +131 -0
  54. package/coverage/lcov-report/lib/models/provider-types.ts.html +577 -0
  55. package/coverage/lcov-report/lib/providers/base-wallet-provider.ts.html +1138 -0
  56. package/coverage/lcov-report/lib/providers/hsuite-native/channel-client.service.ts.html +2671 -0
  57. package/coverage/lcov-report/lib/providers/hsuite-native/index.html +116 -0
  58. package/coverage/lcov-report/lib/providers/hsuite-native-provider.ts.html +2347 -0
  59. package/coverage/lcov-report/lib/providers/index.html +146 -0
  60. package/coverage/lcov-report/lib/providers/p2p-native/index.html +131 -0
  61. package/coverage/lcov-report/lib/providers/p2p-native/p2p-native.provider.ts.html +2254 -0
  62. package/coverage/lcov-report/lib/providers/p2p-native/p2p-session-manager.ts.html +2170 -0
  63. package/coverage/lcov-report/lib/providers/wallet-error-handler.ts.html +1132 -0
  64. package/coverage/lcov-report/lib/providers/walletconnect/core/index.html +176 -0
  65. package/coverage/lcov-report/lib/providers/walletconnect/core/session-health.ts.html +673 -0
  66. package/coverage/lcov-report/lib/providers/walletconnect/core/walletconnect-client-manager.ts.html +1177 -0
  67. package/coverage/lcov-report/lib/providers/walletconnect/core/walletconnect-provider.ts.html +2563 -0
  68. package/coverage/lcov-report/lib/providers/walletconnect/core/walletconnect-session-store.ts.html +904 -0
  69. package/coverage/lcov-report/lib/providers/walletconnect/core/walletconnect-signing-orchestrator.ts.html +982 -0
  70. package/coverage/lcov-report/lib/providers/walletconnect/signers/hedera-signer.ts.html +1915 -0
  71. package/coverage/lcov-report/lib/providers/walletconnect/signers/index.html +146 -0
  72. package/coverage/lcov-report/lib/providers/walletconnect/signers/signer-factory.ts.html +445 -0
  73. package/coverage/lcov-report/lib/providers/walletconnect/signers/xrpl-signer.ts.html +1519 -0
  74. package/coverage/lcov-report/lib/services/index.html +191 -0
  75. package/coverage/lcov-report/lib/services/logger.service.ts.html +463 -0
  76. package/coverage/lcov-report/lib/services/transaction-builders/base-transaction-builder.service.ts.html +1840 -0
  77. package/coverage/lcov-report/lib/services/transaction-builders/hedera-amount-utils.ts.html +337 -0
  78. package/coverage/lcov-report/lib/services/transaction-builders/hedera-transaction-builder.service.ts.html +3940 -0
  79. package/coverage/lcov-report/lib/services/transaction-builders/index.html +161 -0
  80. package/coverage/lcov-report/lib/services/transaction-builders/xrpl-transaction-builder.service.ts.html +2581 -0
  81. package/coverage/lcov-report/lib/services/transaction.service.ts.html +1123 -0
  82. package/coverage/lcov-report/lib/services/unified-wallet.service.ts.html +2641 -0
  83. package/coverage/lcov-report/lib/services/wallet-context.service.ts.html +637 -0
  84. package/coverage/lcov-report/lib/services/wallet-event-bus.service.ts.html +643 -0
  85. package/coverage/lcov-report/lib/services/wallet-providers.service.ts.html +496 -0
  86. package/coverage/lcov-report/lib/transports/chrome-extension-transport.ts.html +823 -0
  87. package/coverage/lcov-report/lib/transports/index.html +116 -0
  88. package/coverage/lcov-report/lib/utils/index.html +116 -0
  89. package/coverage/lcov-report/lib/utils/ledger-icons.util.ts.html +319 -0
  90. package/coverage/lcov-report/prettify.css +1 -0
  91. package/coverage/lcov-report/prettify.js +2 -0
  92. package/coverage/lcov-report/sort-arrow-sprite.png +0 -0
  93. package/coverage/lcov-report/sorter.js +210 -0
  94. package/coverage/lcov.info +19252 -0
  95. package/coverage/lib/components/account-selector/account-actions/account-actions.component.ts.html +868 -0
  96. package/coverage/lib/components/account-selector/account-actions/index.html +116 -0
  97. package/coverage/lib/components/account-selector/account-filter/account-filter.component.ts.html +1288 -0
  98. package/coverage/lib/components/account-selector/account-filter/index.html +116 -0
  99. package/coverage/lib/components/account-selector/account-formatting.service.ts.html +685 -0
  100. package/coverage/lib/components/account-selector/account-grouping.service.ts.html +766 -0
  101. package/coverage/lib/components/account-selector/account-list/account-list.component.ts.html +1495 -0
  102. package/coverage/lib/components/account-selector/account-list/index.html +116 -0
  103. package/coverage/lib/components/account-selector/account-selector.component.ts.html +1495 -0
  104. package/coverage/lib/components/account-selector/account-selector.service.ts.html +1588 -0
  105. package/coverage/lib/components/account-selector/index.html +161 -0
  106. package/coverage/lib/components/wallet-account-display/index.html +116 -0
  107. package/coverage/lib/components/wallet-account-display/wallet-account-display.component.ts.html +505 -0
  108. package/coverage/lib/components/wallet-connect-button/index.html +116 -0
  109. package/coverage/lib/components/wallet-connect-button/wallet-connect-button.component.ts.html +805 -0
  110. package/coverage/lib/components/wallet-connect-prompt/index.html +116 -0
  111. package/coverage/lib/components/wallet-connect-prompt/wallet-connect-prompt.component.ts.html +409 -0
  112. package/coverage/lib/components/wallet-connected-guard/index.html +116 -0
  113. package/coverage/lib/components/wallet-connected-guard/wallet-connected-guard.component.ts.html +304 -0
  114. package/coverage/lib/components/wallet-connection-modal/connection-method-step/connection-method-step.component.ts.html +436 -0
  115. package/coverage/lib/components/wallet-connection-modal/connection-method-step/index.html +116 -0
  116. package/coverage/lib/components/wallet-connection-modal/index.html +116 -0
  117. package/coverage/lib/components/wallet-connection-modal/qr-pairing-step/index.html +116 -0
  118. package/coverage/lib/components/wallet-connection-modal/qr-pairing-step/qr-pairing-step.component.ts.html +2287 -0
  119. package/coverage/lib/components/wallet-connection-modal/wallet-connection-modal.component.ts.html +2275 -0
  120. package/coverage/lib/components/wallet-session-display/index.html +116 -0
  121. package/coverage/lib/components/wallet-session-display/wallet-session-display.component.ts.html +676 -0
  122. package/coverage/lib/components/wallet-transaction-status/index.html +116 -0
  123. package/coverage/lib/components/wallet-transaction-status/wallet-transaction-status.component.ts.html +703 -0
  124. package/coverage/lib/directives/index.html +146 -0
  125. package/coverage/lib/directives/wallet-connected.directive.ts.html +670 -0
  126. package/coverage/lib/directives/wallet-context.directive.ts.html +547 -0
  127. package/coverage/lib/directives/wallet-events.directive.ts.html +781 -0
  128. package/coverage/lib/hsuite-wallet.module.ts.html +715 -0
  129. package/coverage/lib/index.html +116 -0
  130. package/coverage/lib/models/connection-config.model.ts.html +280 -0
  131. package/coverage/lib/models/index.html +131 -0
  132. package/coverage/lib/models/provider-types.ts.html +577 -0
  133. package/coverage/lib/providers/base-wallet-provider.ts.html +1138 -0
  134. package/coverage/lib/providers/hsuite-native/channel-client.service.ts.html +2671 -0
  135. package/coverage/lib/providers/hsuite-native/index.html +116 -0
  136. package/coverage/lib/providers/hsuite-native-provider.ts.html +2347 -0
  137. package/coverage/lib/providers/index.html +146 -0
  138. package/coverage/lib/providers/p2p-native/index.html +131 -0
  139. package/coverage/lib/providers/p2p-native/p2p-native.provider.ts.html +2254 -0
  140. package/coverage/lib/providers/p2p-native/p2p-session-manager.ts.html +2170 -0
  141. package/coverage/lib/providers/wallet-error-handler.ts.html +1132 -0
  142. package/coverage/lib/providers/walletconnect/core/index.html +176 -0
  143. package/coverage/lib/providers/walletconnect/core/session-health.ts.html +673 -0
  144. package/coverage/lib/providers/walletconnect/core/walletconnect-client-manager.ts.html +1177 -0
  145. package/coverage/lib/providers/walletconnect/core/walletconnect-provider.ts.html +2563 -0
  146. package/coverage/lib/providers/walletconnect/core/walletconnect-session-store.ts.html +904 -0
  147. package/coverage/lib/providers/walletconnect/core/walletconnect-signing-orchestrator.ts.html +982 -0
  148. package/coverage/lib/providers/walletconnect/signers/hedera-signer.ts.html +1915 -0
  149. package/coverage/lib/providers/walletconnect/signers/index.html +146 -0
  150. package/coverage/lib/providers/walletconnect/signers/signer-factory.ts.html +445 -0
  151. package/coverage/lib/providers/walletconnect/signers/xrpl-signer.ts.html +1519 -0
  152. package/coverage/lib/services/index.html +191 -0
  153. package/coverage/lib/services/logger.service.ts.html +463 -0
  154. package/coverage/lib/services/transaction-builders/base-transaction-builder.service.ts.html +1840 -0
  155. package/coverage/lib/services/transaction-builders/hedera-amount-utils.ts.html +337 -0
  156. package/coverage/lib/services/transaction-builders/hedera-transaction-builder.service.ts.html +3940 -0
  157. package/coverage/lib/services/transaction-builders/index.html +161 -0
  158. package/coverage/lib/services/transaction-builders/xrpl-transaction-builder.service.ts.html +2581 -0
  159. package/coverage/lib/services/transaction.service.ts.html +1123 -0
  160. package/coverage/lib/services/unified-wallet.service.ts.html +2641 -0
  161. package/coverage/lib/services/wallet-context.service.ts.html +637 -0
  162. package/coverage/lib/services/wallet-event-bus.service.ts.html +643 -0
  163. package/coverage/lib/services/wallet-providers.service.ts.html +496 -0
  164. package/coverage/lib/transports/chrome-extension-transport.ts.html +823 -0
  165. package/coverage/lib/transports/index.html +116 -0
  166. package/coverage/lib/utils/index.html +116 -0
  167. package/coverage/lib/utils/ledger-icons.util.ts.html +319 -0
  168. package/coverage/prettify.css +1 -0
  169. package/coverage/prettify.js +2 -0
  170. package/coverage/sort-arrow-sprite.png +0 -0
  171. package/coverage/sorter.js +210 -0
  172. package/dist/README.md +48 -0
  173. package/dist/fesm2022/hsuite-native-connect-angular.mjs +14592 -0
  174. package/dist/fesm2022/hsuite-native-connect-angular.mjs.map +1 -0
  175. package/dist/index.d.ts +6949 -0
  176. package/examples/minimal-connect.ts +178 -0
  177. package/examples/multi-protocol.ts +495 -0
  178. package/examples/transaction-signing.ts +361 -0
  179. package/jest.config.json +45 -0
  180. package/karma.conf.js +42 -0
  181. package/ng-package.json +20 -0
  182. package/package.json +60 -0
  183. package/src/index.ts +203 -0
  184. package/src/lib/components/account-selector/account-actions/account-actions.component.ts +261 -0
  185. package/src/lib/components/account-selector/account-filter/account-filter.component.ts +401 -0
  186. package/src/lib/components/account-selector/account-formatting.service.ts +200 -0
  187. package/src/lib/components/account-selector/account-grouping.service.ts +227 -0
  188. package/src/lib/components/account-selector/account-list/account-list.component.ts +470 -0
  189. package/src/lib/components/account-selector/account-selector.component.html +135 -0
  190. package/src/lib/components/account-selector/account-selector.component.scss +2039 -0
  191. package/src/lib/components/account-selector/account-selector.component.ts +470 -0
  192. package/src/lib/components/account-selector/account-selector.service.ts +501 -0
  193. package/src/lib/components/wallet-account-display/wallet-account-display.component.html +34 -0
  194. package/src/lib/components/wallet-account-display/wallet-account-display.component.scss +99 -0
  195. package/src/lib/components/wallet-account-display/wallet-account-display.component.ts +140 -0
  196. package/src/lib/components/wallet-connect-button/wallet-connect-button.component.html +14 -0
  197. package/src/lib/components/wallet-connect-button/wallet-connect-button.component.scss +272 -0
  198. package/src/lib/components/wallet-connect-button/wallet-connect-button.component.ts +240 -0
  199. package/src/lib/components/wallet-connect-prompt/wallet-connect-prompt.component.html +24 -0
  200. package/src/lib/components/wallet-connect-prompt/wallet-connect-prompt.component.scss +50 -0
  201. package/src/lib/components/wallet-connect-prompt/wallet-connect-prompt.component.ts +108 -0
  202. package/src/lib/components/wallet-connected-guard/wallet-connected-guard.component.html +24 -0
  203. package/src/lib/components/wallet-connected-guard/wallet-connected-guard.component.ts +73 -0
  204. package/src/lib/components/wallet-connection-modal/connection-method-step/connection-method-step.component.html +56 -0
  205. package/src/lib/components/wallet-connection-modal/connection-method-step/connection-method-step.component.scss +218 -0
  206. package/src/lib/components/wallet-connection-modal/connection-method-step/connection-method-step.component.ts +117 -0
  207. package/src/lib/components/wallet-connection-modal/qr-pairing-step/qr-pairing-step.component.html +94 -0
  208. package/src/lib/components/wallet-connection-modal/qr-pairing-step/qr-pairing-step.component.scss +272 -0
  209. package/src/lib/components/wallet-connection-modal/qr-pairing-step/qr-pairing-step.component.ts +734 -0
  210. package/src/lib/components/wallet-connection-modal/wallet-connection-modal.component.html +197 -0
  211. package/src/lib/components/wallet-connection-modal/wallet-connection-modal.component.scss +678 -0
  212. package/src/lib/components/wallet-connection-modal/wallet-connection-modal.component.ts +730 -0
  213. package/src/lib/components/wallet-session-display/wallet-session-display.component.html +110 -0
  214. package/src/lib/components/wallet-session-display/wallet-session-display.component.scss +179 -0
  215. package/src/lib/components/wallet-session-display/wallet-session-display.component.ts +197 -0
  216. package/src/lib/components/wallet-transaction-status/wallet-transaction-status.component.html +65 -0
  217. package/src/lib/components/wallet-transaction-status/wallet-transaction-status.component.scss +254 -0
  218. package/src/lib/components/wallet-transaction-status/wallet-transaction-status.component.ts +206 -0
  219. package/src/lib/directives/wallet-connected.directive.ts +195 -0
  220. package/src/lib/directives/wallet-context.directive.ts +154 -0
  221. package/src/lib/directives/wallet-events.directive.ts +232 -0
  222. package/src/lib/hsuite-wallet.module.ts +210 -0
  223. package/src/lib/models/connection-config.model.ts +65 -0
  224. package/src/lib/models/provider-types.ts +164 -0
  225. package/src/lib/models/unified-account.model.ts +76 -0
  226. package/src/lib/models/wallet-context.model.ts +121 -0
  227. package/src/lib/models/wallet-events.model.ts +158 -0
  228. package/src/lib/providers/base-wallet-provider.ts +351 -0
  229. package/src/lib/providers/hsuite-native/channel-client.service.spec.ts +73 -0
  230. package/src/lib/providers/hsuite-native/channel-client.service.ts +862 -0
  231. package/src/lib/providers/hsuite-native/index.ts +8 -0
  232. package/src/lib/providers/hsuite-native-provider.ts +754 -0
  233. package/src/lib/providers/mobile-native/mobile-native.provider.spec.ts +19 -0
  234. package/src/lib/providers/p2p-native/index.ts +30 -0
  235. package/src/lib/providers/p2p-native/p2p-native.provider.spec.ts +523 -0
  236. package/src/lib/providers/p2p-native/p2p-native.provider.ts +723 -0
  237. package/src/lib/providers/p2p-native/p2p-session-manager.ts +695 -0
  238. package/src/lib/providers/wallet-error-handler.ts +349 -0
  239. package/src/lib/providers/walletconnect/core/base-signer.interface.ts +122 -0
  240. package/src/lib/providers/walletconnect/core/session-health.ts +196 -0
  241. package/src/lib/providers/walletconnect/core/walletconnect-client-manager.ts +364 -0
  242. package/src/lib/providers/walletconnect/core/walletconnect-provider.integration.spec.ts +348 -0
  243. package/src/lib/providers/walletconnect/core/walletconnect-provider.ts +826 -0
  244. package/src/lib/providers/walletconnect/core/walletconnect-session-store.ts +273 -0
  245. package/src/lib/providers/walletconnect/core/walletconnect-signing-orchestrator.ts +299 -0
  246. package/src/lib/providers/walletconnect/core/walletconnect-types.ts +48 -0
  247. package/src/lib/providers/walletconnect/index.ts +33 -0
  248. package/src/lib/providers/walletconnect/signers/hedera-signer.spec.ts +367 -0
  249. package/src/lib/providers/walletconnect/signers/hedera-signer.ts +610 -0
  250. package/src/lib/providers/walletconnect/signers/signer-factory.spec.ts +62 -0
  251. package/src/lib/providers/walletconnect/signers/signer-factory.ts +120 -0
  252. package/src/lib/providers/walletconnect/signers/xrpl-signer.spec.ts +296 -0
  253. package/src/lib/providers/walletconnect/signers/xrpl-signer.ts +478 -0
  254. package/src/lib/services/logger.service.ts +126 -0
  255. package/src/lib/services/transaction-builders/base-transaction-builder.service.ts +585 -0
  256. package/src/lib/services/transaction-builders/hedera-amount-utils.ts +84 -0
  257. package/src/lib/services/transaction-builders/hedera-transaction-builder.service.spec.ts +741 -0
  258. package/src/lib/services/transaction-builders/hedera-transaction-builder.service.ts +1285 -0
  259. package/src/lib/services/transaction-builders/index.ts +54 -0
  260. package/src/lib/services/transaction-builders/xrpl-transaction-builder.service.spec.ts +937 -0
  261. package/src/lib/services/transaction-builders/xrpl-transaction-builder.service.ts +832 -0
  262. package/src/lib/services/transaction.service.ts +346 -0
  263. package/src/lib/services/unified-wallet.service.spec.ts +1382 -0
  264. package/src/lib/services/unified-wallet.service.ts +852 -0
  265. package/src/lib/services/wallet-context.service.ts +184 -0
  266. package/src/lib/services/wallet-event-bus.service.ts +186 -0
  267. package/src/lib/services/wallet-providers.service.ts +137 -0
  268. package/src/lib/transports/chrome-extension-transport.ts +246 -0
  269. package/src/lib/utils/index.ts +14 -0
  270. package/src/lib/utils/ledger-icons.util.ts +78 -0
  271. package/test/test-setup.ts +21 -0
  272. package/test-setup.ts +63 -0
  273. package/tsconfig.build.json +11 -0
  274. package/tsconfig.json +29 -0
  275. package/tsconfig.spec.json +15 -0
  276. package/vitest.config.ts +48 -0
@@ -0,0 +1,94 @@
1
+ <!-- QR Pairing Step -->
2
+ <div class="qr-pairing-step">
3
+ <!-- Header -->
4
+ <div class="step-header">
5
+ <button type="button" class="back-button" (click)="cancel()">
6
+ <ion-icon name="arrow-back-outline"></ion-icon>
7
+ </button>
8
+ <div class="header-content">
9
+ <h3 class="step-title">Connect Mobile Wallet</h3>
10
+ <p class="step-description">Scan the QR code with your HSuite Wallet app</p>
11
+ </div>
12
+ </div>
13
+
14
+ <!-- Loading State -->
15
+ <div class="state-container loading" *ngIf="pairingState() === 'loading'">
16
+ <ion-spinner name="crescent"></ion-spinner>
17
+ <p>Generating secure connection...</p>
18
+ </div>
19
+
20
+ <!-- QR Display State -->
21
+ <div class="qr-container" *ngIf="isQrVisible()">
22
+ <hs-qr-pairing-display
23
+ [offerData]="offerData"
24
+ [size]="256"
25
+ [expirySeconds]="expirySeconds"
26
+ title="Scan to Connect"
27
+ [subtitle]="appName + ' wants to connect'"
28
+ (expired)="onQrExpired()"
29
+ (refreshRequested)="refresh()"
30
+ ></hs-qr-pairing-display>
31
+ </div>
32
+
33
+ <!-- Connecting State -->
34
+ <div class="state-container connecting" *ngIf="pairingState() === 'connecting'">
35
+ <div class="connecting-animation">
36
+ <ion-icon name="phone-portrait-outline"></ion-icon>
37
+ <div class="connecting-dots">
38
+ <span></span>
39
+ <span></span>
40
+ <span></span>
41
+ </div>
42
+ <ion-icon name="qr-code-outline"></ion-icon>
43
+ </div>
44
+ <p>Establishing secure connection...</p>
45
+ <span class="hint">Approve the connection request on your wallet</span>
46
+ </div>
47
+
48
+ <!-- Connected State -->
49
+ <div class="state-container connected" *ngIf="pairingState() === 'connected'">
50
+ <ion-icon name="checkmark-circle-outline" class="success-icon"></ion-icon>
51
+ <p>Connected successfully!</p>
52
+ </div>
53
+
54
+ <!-- Expired State -->
55
+ <div class="state-container expired" *ngIf="pairingState() === 'expired'">
56
+ <ion-icon name="close-circle-outline" class="expired-icon"></ion-icon>
57
+ <p>QR code expired</p>
58
+ <button type="button" class="refresh-button" (click)="refresh()">
59
+ <ion-icon name="refresh-outline"></ion-icon>
60
+ Generate New Code
61
+ </button>
62
+ </div>
63
+
64
+ <!-- Error State -->
65
+ <div class="state-container error" *ngIf="pairingState() === 'error'">
66
+ <ion-icon name="close-circle-outline" class="error-icon"></ion-icon>
67
+ <p>{{ errorMessage || 'Something went wrong' }}</p>
68
+ <button type="button" class="refresh-button" (click)="refresh()">
69
+ <ion-icon name="refresh-outline"></ion-icon>
70
+ Try Again
71
+ </button>
72
+ </div>
73
+
74
+ <!-- Instructions -->
75
+ <div class="instructions" *ngIf="pairingState() === 'displaying'">
76
+ <h4>How to connect:</h4>
77
+ <ol>
78
+ <li>Open the <strong>HSuite Wallet</strong> app on your phone</li>
79
+ <li>Go to <strong>Sessions</strong> and tap <strong>Scan QR</strong></li>
80
+ <li>Scan this QR code with your camera</li>
81
+ <li>Approve the connection request</li>
82
+ </ol>
83
+ </div>
84
+
85
+ <!-- Cancel Button -->
86
+ <button
87
+ type="button"
88
+ class="cancel-button"
89
+ *ngIf="pairingState() !== 'connected'"
90
+ (click)="cancel()"
91
+ >
92
+ Cancel
93
+ </button>
94
+ </div>
@@ -0,0 +1,272 @@
1
+ /**
2
+ * QR Pairing Step Styles
3
+ * Uses unified --token-* and Ionic color system for theme compatibility
4
+ */
5
+
6
+ :host {
7
+ display: block;
8
+ }
9
+
10
+ .qr-pairing-step {
11
+ display: flex;
12
+ flex-direction: column;
13
+ align-items: center;
14
+ padding: var(--token-space-4, 16px);
15
+ min-height: 400px;
16
+ }
17
+
18
+ // ========== Header ==========
19
+
20
+ .step-header {
21
+ display: flex;
22
+ align-items: flex-start;
23
+ width: 100%;
24
+ margin-bottom: var(--token-space-6, 24px);
25
+ }
26
+
27
+ .back-button {
28
+ display: flex;
29
+ align-items: center;
30
+ justify-content: center;
31
+ width: 32px;
32
+ height: 32px;
33
+ padding: 0;
34
+ margin-right: var(--token-space-3, 12px);
35
+ background: transparent;
36
+ border: none;
37
+ border-radius: 50%;
38
+ cursor: pointer;
39
+ color: var(--ion-color-medium);
40
+ transition: all var(--token-transition-normal, 0.2s) ease;
41
+
42
+ &:hover {
43
+ background: var(--token-surface-hover, rgba(var(--ion-text-color-rgb), 0.05));
44
+ color: var(--ion-text-color);
45
+ }
46
+
47
+ ion-icon {
48
+ font-size: 20px;
49
+ }
50
+ }
51
+
52
+ .header-content {
53
+ flex: 1;
54
+ }
55
+
56
+ .step-title {
57
+ margin: 0 0 4px;
58
+ font-size: var(--token-font-size-4, 18px);
59
+ font-weight: var(--token-font-weight-semibold, 600);
60
+ color: var(--ion-text-color);
61
+ }
62
+
63
+ .step-description {
64
+ margin: 0;
65
+ font-size: var(--token-font-size-2, 14px);
66
+ color: var(--ion-color-medium);
67
+ }
68
+
69
+ // ========== QR Container ==========
70
+
71
+ .qr-container {
72
+ display: flex;
73
+ justify-content: center;
74
+ margin-bottom: var(--token-space-6, 24px);
75
+ }
76
+
77
+ // ========== State Containers ==========
78
+
79
+ .state-container {
80
+ display: flex;
81
+ flex-direction: column;
82
+ align-items: center;
83
+ justify-content: center;
84
+ padding: var(--token-space-8, 32px);
85
+ text-align: center;
86
+ flex: 1;
87
+
88
+ p {
89
+ margin: var(--token-space-4, 16px) 0 0;
90
+ font-size: var(--token-font-size-3, 16px);
91
+ font-weight: var(--token-font-weight-medium, 500);
92
+ color: var(--ion-text-color);
93
+ }
94
+
95
+ .hint {
96
+ display: block;
97
+ margin-top: var(--token-space-2, 8px);
98
+ font-size: var(--token-font-size-2, 14px);
99
+ font-weight: var(--token-font-weight-normal, 400);
100
+ color: var(--ion-color-medium);
101
+ }
102
+
103
+ ion-spinner {
104
+ width: 48px;
105
+ height: 48px;
106
+ --color: var(--ion-color-primary);
107
+ }
108
+ }
109
+
110
+ // ========== Connecting Animation ==========
111
+
112
+ .connecting-animation {
113
+ display: flex;
114
+ align-items: center;
115
+ gap: var(--token-space-3, 12px);
116
+
117
+ ion-icon {
118
+ font-size: 40px;
119
+ color: var(--ion-color-primary);
120
+ }
121
+ }
122
+
123
+ .connecting-dots {
124
+ display: flex;
125
+ gap: 6px;
126
+
127
+ span {
128
+ width: 8px;
129
+ height: 8px;
130
+ background: var(--ion-color-primary);
131
+ border-radius: 50%;
132
+ animation: pulse 1.4s infinite ease-in-out;
133
+
134
+ &:nth-child(1) {
135
+ animation-delay: 0s;
136
+ }
137
+ &:nth-child(2) {
138
+ animation-delay: 0.2s;
139
+ }
140
+ &:nth-child(3) {
141
+ animation-delay: 0.4s;
142
+ }
143
+ }
144
+ }
145
+
146
+ @keyframes pulse {
147
+ 0%,
148
+ 80%,
149
+ 100% {
150
+ opacity: 0.3;
151
+ transform: scale(0.8);
152
+ }
153
+ 40% {
154
+ opacity: 1;
155
+ transform: scale(1);
156
+ }
157
+ }
158
+
159
+ // ========== Status Icons ==========
160
+
161
+ .success-icon {
162
+ font-size: 64px;
163
+ color: var(--ion-color-success);
164
+ }
165
+
166
+ .expired-icon,
167
+ .error-icon {
168
+ font-size: 64px;
169
+ color: var(--ion-color-warning);
170
+ }
171
+
172
+ .error-icon {
173
+ color: var(--ion-color-danger);
174
+ }
175
+
176
+ // ========== Refresh Button ==========
177
+
178
+ .refresh-button {
179
+ display: flex;
180
+ align-items: center;
181
+ gap: var(--token-space-2, 8px);
182
+ margin-top: var(--token-space-4, 16px);
183
+ padding: var(--token-space-3, 12px) var(--token-space-4, 16px);
184
+ background: var(--ion-color-primary);
185
+ color: var(--ion-color-primary-contrast);
186
+ font-size: var(--token-font-size-2, 14px);
187
+ font-weight: var(--token-font-weight-medium, 500);
188
+ border: none;
189
+ border-radius: var(--token-radius-2, 8px);
190
+ cursor: pointer;
191
+ transition: all var(--token-transition-normal, 0.2s) ease;
192
+
193
+ &:hover {
194
+ background: var(--ion-color-primary-shade);
195
+ }
196
+
197
+ ion-icon {
198
+ font-size: 18px;
199
+ }
200
+ }
201
+
202
+ // ========== Instructions ==========
203
+
204
+ .instructions {
205
+ width: 100%;
206
+ max-width: 320px;
207
+ padding: var(--token-space-4, 16px);
208
+ background: var(--token-surface-3, rgba(var(--ion-text-color-rgb), 0.04));
209
+ border-radius: var(--token-radius-2, 8px);
210
+ margin-bottom: var(--token-space-6, 24px);
211
+
212
+ h4 {
213
+ margin: 0 0 var(--token-space-3, 12px);
214
+ font-size: var(--token-font-size-2, 14px);
215
+ font-weight: var(--token-font-weight-semibold, 600);
216
+ color: var(--ion-text-color);
217
+ }
218
+
219
+ ol {
220
+ margin: 0;
221
+ padding-left: 1.5em;
222
+
223
+ li {
224
+ margin-bottom: var(--token-space-2, 8px);
225
+ font-size: var(--token-font-size-2, 14px);
226
+ color: var(--ion-color-medium);
227
+ line-height: 1.5;
228
+
229
+ &:last-child {
230
+ margin-bottom: 0;
231
+ }
232
+
233
+ strong {
234
+ color: var(--ion-text-color);
235
+ }
236
+ }
237
+ }
238
+ }
239
+
240
+ // ========== Cancel Button ==========
241
+
242
+ .cancel-button {
243
+ margin-top: auto;
244
+ padding: var(--token-space-3, 12px) var(--token-space-6, 24px);
245
+ background: transparent;
246
+ color: var(--ion-color-medium);
247
+ font-size: var(--token-font-size-2, 14px);
248
+ font-weight: var(--token-font-weight-medium, 500);
249
+ border: none;
250
+ cursor: pointer;
251
+ transition: color var(--token-transition-normal, 0.2s) ease;
252
+
253
+ &:hover {
254
+ color: var(--ion-text-color);
255
+ }
256
+ }
257
+
258
+ // ========== Reduced Motion Support ==========
259
+
260
+ @media (prefers-reduced-motion: reduce) {
261
+ .connecting-dots span {
262
+ animation: none;
263
+ opacity: 1;
264
+ transform: scale(1);
265
+ }
266
+
267
+ .back-button,
268
+ .refresh-button,
269
+ .cancel-button {
270
+ transition: none;
271
+ }
272
+ }