@swype-org/react-sdk 0.1.56 → 0.1.63

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.
package/dist/index.cjs CHANGED
@@ -680,7 +680,7 @@ function createPasskeyViaPopup(options) {
680
680
  return new Promise((resolve, reject) => {
681
681
  const encoded = btoa(JSON.stringify(options));
682
682
  const popupUrl = `${window.location.origin}/passkey-register#${encoded}`;
683
- const popup = window.open(popupUrl, "swype-passkey", "width=460,height=600");
683
+ const popup = window.open(popupUrl, "swype-passkey");
684
684
  if (!popup) {
685
685
  reject(new Error("Pop-up blocked. Please allow pop-ups for this site and try again."));
686
686
  return;
@@ -1944,10 +1944,20 @@ function LimitSlider({
1944
1944
  }
1945
1945
  )
1946
1946
  ] }),
1947
- ticks && ticks.length > 0 && /* @__PURE__ */ jsxRuntime.jsx("div", { style: ticksStyle, children: ticks.map((tick) => /* @__PURE__ */ jsxRuntime.jsxs("span", { style: tickLabelStyle(tokens.textMuted), children: [
1948
- "$",
1949
- tick
1950
- ] }, tick)) }),
1947
+ ticks && ticks.length > 0 && /* @__PURE__ */ jsxRuntime.jsx("div", { style: ticksStyle, children: ticks.map((tick, i) => {
1948
+ const pctPos = (tick - min) / (max - min) * 100;
1949
+ const isFirst = i === 0;
1950
+ const isLast = i === ticks.length - 1;
1951
+ const label = tick % 1 === 0 ? `$${tick}` : `$${tick.toFixed(2)}`;
1952
+ return /* @__PURE__ */ jsxRuntime.jsx(
1953
+ "span",
1954
+ {
1955
+ style: tickLabelStyle(tokens.textMuted, pctPos, isFirst, isLast),
1956
+ children: label
1957
+ },
1958
+ tick
1959
+ );
1960
+ }) }),
1951
1961
  /* @__PURE__ */ jsxRuntime.jsx("style", { children: sliderThumbCss(tokens.accent) })
1952
1962
  ] });
1953
1963
  }
@@ -1988,14 +1998,18 @@ var rangeInputStyle = {
1988
1998
  background: "transparent"
1989
1999
  };
1990
2000
  var ticksStyle = {
1991
- display: "flex",
1992
- justifyContent: "space-between",
2001
+ position: "relative",
2002
+ height: 18,
1993
2003
  marginTop: 6
1994
2004
  };
1995
- var tickLabelStyle = (color) => ({
2005
+ var tickLabelStyle = (color, pct, isFirst, isLast) => ({
2006
+ position: "absolute",
2007
+ left: `${pct}%`,
2008
+ transform: isFirst ? "none" : isLast ? "translateX(-100%)" : "translateX(-50%)",
1996
2009
  fontSize: "0.72rem",
1997
2010
  fontWeight: 500,
1998
- color
2011
+ color,
2012
+ whiteSpace: "nowrap"
1999
2013
  });
2000
2014
  var sliderThumbCss = (accent) => `
2001
2015
  .swype-slider-wrap input[type="range"]::-webkit-slider-runnable-track {
@@ -3008,11 +3022,13 @@ function SetupScreen({
3008
3022
  onSetupOneTap,
3009
3023
  onBack,
3010
3024
  onLogout,
3025
+ onAdvanced,
3026
+ selectedSourceLabel,
3011
3027
  loading,
3012
3028
  error
3013
3029
  }) {
3014
3030
  const { tokens } = useSwypeConfig();
3015
- const effectiveMax = Math.min(DEFAULT_MAX, availableBalance > 0 ? availableBalance : DEFAULT_MAX);
3031
+ const effectiveMax = Math.floor(Math.min(DEFAULT_MAX, availableBalance > 0 ? availableBalance : DEFAULT_MAX) * 100) / 100;
3016
3032
  const effectiveMin = Math.min(ABSOLUTE_MIN, effectiveMax);
3017
3033
  const sliderStep = effectiveMax <= 10 ? 0.5 : effectiveMax <= 50 ? 1 : 5;
3018
3034
  const ticks = buildTicks(effectiveMin, effectiveMax);
@@ -3051,18 +3067,30 @@ function SetupScreen({
3051
3067
  ] })
3052
3068
  ] })
3053
3069
  ] }),
3054
- tokenCount > 0 && /* @__PURE__ */ jsxRuntime.jsxs("div", { style: tokenBadgeStyle(tokens), children: [
3055
- /* @__PURE__ */ jsxRuntime.jsx("span", { style: tokenDotStyle(tokens.accent) }),
3056
- tokenCount,
3057
- " ",
3058
- /* @__PURE__ */ jsxRuntime.jsx("span", { style: chevronStyle, children: ">" })
3059
- ] })
3070
+ tokenCount > 0 && /* @__PURE__ */ jsxRuntime.jsxs(
3071
+ "button",
3072
+ {
3073
+ type: "button",
3074
+ onClick: onAdvanced,
3075
+ style: tokenBadgeButtonStyle(tokens, !!onAdvanced),
3076
+ children: [
3077
+ /* @__PURE__ */ jsxRuntime.jsx("span", { style: tokenDotStyle(tokens.accent) }),
3078
+ tokenCount,
3079
+ " ",
3080
+ /* @__PURE__ */ jsxRuntime.jsx("span", { style: chevronStyle, children: ">" })
3081
+ ]
3082
+ }
3083
+ )
3084
+ ] }),
3085
+ selectedSourceLabel && /* @__PURE__ */ jsxRuntime.jsxs("div", { style: selectedSourceStyle(tokens.textSecondary), children: [
3086
+ "Source: ",
3087
+ /* @__PURE__ */ jsxRuntime.jsx("strong", { children: selectedSourceLabel })
3060
3088
  ] }),
3061
3089
  /* @__PURE__ */ jsxRuntime.jsxs("div", { style: limitSectionStyle, children: [
3062
3090
  /* @__PURE__ */ jsxRuntime.jsx("div", { style: limitLabelStyle(tokens.textMuted), children: "Your One-Tap limit" }),
3063
3091
  /* @__PURE__ */ jsxRuntime.jsxs("div", { style: limitValueStyle(tokens.text), children: [
3064
3092
  "$",
3065
- limit
3093
+ limit.toFixed(2)
3066
3094
  ] }),
3067
3095
  /* @__PURE__ */ jsxRuntime.jsx(
3068
3096
  LimitSlider,
@@ -3137,7 +3165,7 @@ var balanceValueStyle = (color) => ({
3137
3165
  fontWeight: 700,
3138
3166
  color
3139
3167
  });
3140
- var tokenBadgeStyle = (tokens) => ({
3168
+ var tokenBadgeButtonStyle = (tokens, clickable) => ({
3141
3169
  display: "flex",
3142
3170
  alignItems: "center",
3143
3171
  gap: 4,
@@ -3145,7 +3173,16 @@ var tokenBadgeStyle = (tokens) => ({
3145
3173
  color: tokens.textMuted,
3146
3174
  border: `1px solid ${tokens.border}`,
3147
3175
  borderRadius: 999,
3148
- padding: "4px 10px"
3176
+ padding: "4px 10px",
3177
+ background: "transparent",
3178
+ fontFamily: "inherit",
3179
+ cursor: clickable ? "pointer" : "default"
3180
+ });
3181
+ var selectedSourceStyle = (color) => ({
3182
+ fontSize: "0.8rem",
3183
+ color,
3184
+ marginBottom: 16,
3185
+ textAlign: "center"
3149
3186
  });
3150
3187
  var tokenDotStyle = (color) => ({
3151
3188
  width: 8,
@@ -3310,7 +3347,7 @@ function DepositScreen({
3310
3347
  ] })
3311
3348
  ] })
3312
3349
  ] }),
3313
- tokenCount > 0 && /* @__PURE__ */ jsxRuntime.jsxs("div", { style: tokenBadgeStyle2(tokens), children: [
3350
+ tokenCount > 0 && /* @__PURE__ */ jsxRuntime.jsxs("div", { style: tokenBadgeStyle(tokens), children: [
3314
3351
  /* @__PURE__ */ jsxRuntime.jsx("span", { style: tokenDotStyle2(tokens.accent) }),
3315
3352
  tokenCount,
3316
3353
  " ",
@@ -3373,7 +3410,7 @@ var balanceAmountStyle = {
3373
3410
  fontSize: "1rem",
3374
3411
  fontWeight: 700
3375
3412
  };
3376
- var tokenBadgeStyle2 = (tokens) => ({
3413
+ var tokenBadgeStyle = (tokens) => ({
3377
3414
  display: "flex",
3378
3415
  alignItems: "center",
3379
3416
  gap: 4,
@@ -3778,6 +3815,228 @@ var radioDotStyle = (color) => ({
3778
3815
  borderRadius: "50%",
3779
3816
  background: color
3780
3817
  });
3818
+ function AdvancedSourceScreen({
3819
+ choices,
3820
+ selectedChainName,
3821
+ selectedTokenSymbol,
3822
+ onSelectSource,
3823
+ onBack
3824
+ }) {
3825
+ const { tokens } = useSwypeConfig();
3826
+ const [expandedChain, setExpandedChain] = react.useState(
3827
+ selectedChainName || (choices[0]?.chainName ?? null)
3828
+ );
3829
+ const [localChain, setLocalChain] = react.useState(selectedChainName);
3830
+ const [localToken, setLocalToken] = react.useState(selectedTokenSymbol);
3831
+ const canConfirm = !!localChain && !!localToken;
3832
+ const handleChainToggle = (chainName) => {
3833
+ setExpandedChain((prev) => prev === chainName ? null : chainName);
3834
+ };
3835
+ const handleTokenSelect = (chainName, tokenSymbol) => {
3836
+ setLocalChain(chainName);
3837
+ setLocalToken(tokenSymbol);
3838
+ setExpandedChain(chainName);
3839
+ };
3840
+ return /* @__PURE__ */ jsxRuntime.jsxs(
3841
+ ScreenLayout,
3842
+ {
3843
+ footer: /* @__PURE__ */ jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [
3844
+ /* @__PURE__ */ jsxRuntime.jsx(
3845
+ PrimaryButton,
3846
+ {
3847
+ onClick: () => onSelectSource(localChain, localToken),
3848
+ disabled: !canConfirm,
3849
+ children: "Select Source"
3850
+ }
3851
+ ),
3852
+ /* @__PURE__ */ jsxRuntime.jsx(PoweredByFooter, {})
3853
+ ] }),
3854
+ children: [
3855
+ /* @__PURE__ */ jsxRuntime.jsx(
3856
+ ScreenHeader,
3857
+ {
3858
+ title: "Swype Setup",
3859
+ onBack,
3860
+ right: /* @__PURE__ */ jsxRuntime.jsx("span", { style: advancedBadgeStyle(tokens.accent), children: "Advanced" })
3861
+ }
3862
+ ),
3863
+ /* @__PURE__ */ jsxRuntime.jsx("h2", { style: headingStyle7(tokens.text), children: "Set up One-Tap deposits" }),
3864
+ /* @__PURE__ */ jsxRuntime.jsx("p", { style: subtitleStyle8(tokens.textSecondary), children: "Select a token source for your One-Tap deposits." }),
3865
+ /* @__PURE__ */ jsxRuntime.jsx("label", { style: labelStyle3(tokens.textSecondary), children: "Select tokens to approve" }),
3866
+ /* @__PURE__ */ jsxRuntime.jsx("div", { style: chainListStyle, children: choices.map((chain) => {
3867
+ const isExpanded = expandedChain === chain.chainName;
3868
+ const chainHasSelection = localChain === chain.chainName;
3869
+ return /* @__PURE__ */ jsxRuntime.jsxs("div", { style: chainCardStyle(tokens), children: [
3870
+ /* @__PURE__ */ jsxRuntime.jsxs(
3871
+ "button",
3872
+ {
3873
+ type: "button",
3874
+ onClick: () => handleChainToggle(chain.chainName),
3875
+ style: chainHeaderStyle(tokens),
3876
+ children: [
3877
+ /* @__PURE__ */ jsxRuntime.jsxs("div", { style: chainHeaderLeftStyle, children: [
3878
+ /* @__PURE__ */ jsxRuntime.jsx("span", { style: chainNameStyle(tokens.text), children: chain.chainName }),
3879
+ /* @__PURE__ */ jsxRuntime.jsxs("span", { style: chainBalanceStyle(tokens.textMuted), children: [
3880
+ "$",
3881
+ chain.balance.toLocaleString("en-US", { minimumFractionDigits: 2, maximumFractionDigits: 2 })
3882
+ ] })
3883
+ ] }),
3884
+ /* @__PURE__ */ jsxRuntime.jsx("span", { style: chevronIconStyle(isExpanded, tokens.textMuted), children: isExpanded ? "\u25BE" : "\u25B8" })
3885
+ ]
3886
+ }
3887
+ ),
3888
+ isExpanded && /* @__PURE__ */ jsxRuntime.jsx("div", { style: tokenListStyle, children: chain.tokens.map((token) => {
3889
+ const isSelected = chainHasSelection && localToken === token.tokenSymbol;
3890
+ return /* @__PURE__ */ jsxRuntime.jsxs(
3891
+ "button",
3892
+ {
3893
+ type: "button",
3894
+ onClick: () => handleTokenSelect(chain.chainName, token.tokenSymbol),
3895
+ style: tokenRowStyle(tokens, isSelected),
3896
+ children: [
3897
+ /* @__PURE__ */ jsxRuntime.jsxs("div", { style: tokenInfoStyle, children: [
3898
+ /* @__PURE__ */ jsxRuntime.jsx("span", { style: tokenSymbolStyle(tokens.text), children: token.tokenSymbol }),
3899
+ /* @__PURE__ */ jsxRuntime.jsxs("span", { style: tokenBalStyle(tokens.textMuted), children: [
3900
+ "Balance: ",
3901
+ token.balance.toLocaleString("en-US", { minimumFractionDigits: 2, maximumFractionDigits: 2 }),
3902
+ " ",
3903
+ token.tokenSymbol
3904
+ ] })
3905
+ ] }),
3906
+ /* @__PURE__ */ jsxRuntime.jsx("div", { style: radioStyle2(tokens, isSelected), children: isSelected && /* @__PURE__ */ jsxRuntime.jsx("div", { style: radioDotStyle2(tokens.accent) }) })
3907
+ ]
3908
+ },
3909
+ token.tokenSymbol
3910
+ );
3911
+ }) })
3912
+ ] }, chain.chainName);
3913
+ }) })
3914
+ ]
3915
+ }
3916
+ );
3917
+ }
3918
+ var advancedBadgeStyle = (color) => ({
3919
+ fontSize: "0.72rem",
3920
+ fontWeight: 600,
3921
+ color,
3922
+ border: `1px solid ${color}`,
3923
+ borderRadius: 999,
3924
+ padding: "3px 10px",
3925
+ letterSpacing: "0.02em"
3926
+ });
3927
+ var headingStyle7 = (color) => ({
3928
+ fontSize: "1.3rem",
3929
+ fontWeight: 700,
3930
+ letterSpacing: "-0.02em",
3931
+ color,
3932
+ margin: "8px 0 4px"
3933
+ });
3934
+ var subtitleStyle8 = (color) => ({
3935
+ fontSize: "0.86rem",
3936
+ color,
3937
+ margin: "0 0 20px",
3938
+ lineHeight: 1.5
3939
+ });
3940
+ var labelStyle3 = (color) => ({
3941
+ display: "block",
3942
+ fontSize: "0.75rem",
3943
+ fontWeight: 600,
3944
+ color,
3945
+ textTransform: "uppercase",
3946
+ letterSpacing: "0.05em",
3947
+ marginBottom: 10
3948
+ });
3949
+ var chainListStyle = {
3950
+ display: "flex",
3951
+ flexDirection: "column",
3952
+ gap: 10
3953
+ };
3954
+ var chainCardStyle = (tokens) => ({
3955
+ border: `1px solid ${tokens.border}`,
3956
+ borderRadius: 14,
3957
+ overflow: "hidden",
3958
+ background: tokens.bgInput
3959
+ });
3960
+ var chainHeaderStyle = (tokens, _expanded) => ({
3961
+ display: "flex",
3962
+ alignItems: "center",
3963
+ justifyContent: "space-between",
3964
+ width: "100%",
3965
+ padding: "14px 16px",
3966
+ background: tokens.bgInput,
3967
+ border: "none",
3968
+ cursor: "pointer",
3969
+ fontFamily: "inherit",
3970
+ textAlign: "left"
3971
+ });
3972
+ var chainHeaderLeftStyle = {
3973
+ display: "flex",
3974
+ flexDirection: "column",
3975
+ gap: 2
3976
+ };
3977
+ var chainNameStyle = (color) => ({
3978
+ fontSize: "0.92rem",
3979
+ fontWeight: 600,
3980
+ color
3981
+ });
3982
+ var chainBalanceStyle = (color) => ({
3983
+ fontSize: "0.76rem",
3984
+ color
3985
+ });
3986
+ var chevronIconStyle = (_expanded, color) => ({
3987
+ fontSize: "0.9rem",
3988
+ color,
3989
+ transition: "transform 0.15s ease"
3990
+ });
3991
+ var tokenListStyle = {
3992
+ padding: "0 12px 12px",
3993
+ display: "flex",
3994
+ flexDirection: "column",
3995
+ gap: 6
3996
+ };
3997
+ var tokenRowStyle = (tokens, selected) => ({
3998
+ display: "flex",
3999
+ alignItems: "center",
4000
+ justifyContent: "space-between",
4001
+ padding: "12px 14px",
4002
+ background: tokens.bgCard,
4003
+ border: `1.5px solid ${selected ? tokens.accent : tokens.border}`,
4004
+ borderRadius: 10,
4005
+ cursor: "pointer",
4006
+ fontFamily: "inherit",
4007
+ textAlign: "left",
4008
+ transition: "border-color 0.15s ease"
4009
+ });
4010
+ var tokenInfoStyle = {
4011
+ display: "flex",
4012
+ flexDirection: "column",
4013
+ gap: 2
4014
+ };
4015
+ var tokenSymbolStyle = (color) => ({
4016
+ fontSize: "0.88rem",
4017
+ fontWeight: 600,
4018
+ color
4019
+ });
4020
+ var tokenBalStyle = (color) => ({
4021
+ fontSize: "0.74rem",
4022
+ color
4023
+ });
4024
+ var radioStyle2 = (tokens, selected) => ({
4025
+ width: 20,
4026
+ height: 20,
4027
+ borderRadius: "50%",
4028
+ border: `2px solid ${selected ? tokens.accent : tokens.border}`,
4029
+ display: "flex",
4030
+ alignItems: "center",
4031
+ justifyContent: "center",
4032
+ flexShrink: 0
4033
+ });
4034
+ var radioDotStyle2 = (color) => ({
4035
+ width: 10,
4036
+ height: 10,
4037
+ borderRadius: "50%",
4038
+ background: color
4039
+ });
3781
4040
  var STEP_LABELS = ["Creating transfer", "Verifying", "Sent", "Done"];
3782
4041
  var PHASE_ACTIVE_INDEX = {
3783
4042
  creating: 0,
@@ -3803,7 +4062,7 @@ function TransferStatusScreen({
3803
4062
  /* @__PURE__ */ jsxRuntime.jsx(ScreenHeader, { right: /* @__PURE__ */ jsxRuntime.jsx(SettingsMenu, { onLogout }) }),
3804
4063
  /* @__PURE__ */ jsxRuntime.jsxs("div", { style: contentStyle5, children: [
3805
4064
  /* @__PURE__ */ jsxRuntime.jsx(Spinner, { size: 48 }),
3806
- /* @__PURE__ */ jsxRuntime.jsx("h2", { style: headingStyle7(tokens.text), children: "Processing Transfer..." }),
4065
+ /* @__PURE__ */ jsxRuntime.jsx("h2", { style: headingStyle8(tokens.text), children: "Processing Transfer..." }),
3807
4066
  error && /* @__PURE__ */ jsxRuntime.jsx("div", { style: errorBannerStyle5(tokens), children: error }),
3808
4067
  /* @__PURE__ */ jsxRuntime.jsx("div", { style: stepsWrapStyle, children: /* @__PURE__ */ jsxRuntime.jsx(StepList, { steps }) }),
3809
4068
  /* @__PURE__ */ jsxRuntime.jsx("p", { style: waitHintStyle(tokens.textMuted), children: "Usually takes a few seconds" })
@@ -3819,7 +4078,7 @@ var contentStyle5 = {
3819
4078
  textAlign: "center",
3820
4079
  padding: "0 24px"
3821
4080
  };
3822
- var headingStyle7 = (color) => ({
4081
+ var headingStyle8 = (color) => ({
3823
4082
  fontSize: "1.45rem",
3824
4083
  fontWeight: 700,
3825
4084
  letterSpacing: "-0.02em",
@@ -3858,6 +4117,12 @@ function OpenWalletScreen({
3858
4117
  const { tokens } = useSwypeConfig();
3859
4118
  const displayName = walletName ?? "your wallet";
3860
4119
  const logoSrc = walletName ? KNOWN_LOGOS[walletName.toLowerCase()] : void 0;
4120
+ const autoOpenedRef = react.useRef(null);
4121
+ react.useEffect(() => {
4122
+ if (loading || !deeplinkUri || autoOpenedRef.current === deeplinkUri) return;
4123
+ autoOpenedRef.current = deeplinkUri;
4124
+ window.location.href = deeplinkUri;
4125
+ }, [loading, deeplinkUri]);
3861
4126
  const handleOpen = react.useCallback(() => {
3862
4127
  const opened = window.open(deeplinkUri, "_blank");
3863
4128
  if (!opened && window === window.parent) {
@@ -3872,14 +4137,14 @@ function OpenWalletScreen({
3872
4137
  "Open ",
3873
4138
  displayName
3874
4139
  ] }),
3875
- /* @__PURE__ */ jsxRuntime.jsx("p", { style: hintStyle3(tokens.textMuted), children: loading ? "Preparing authorization..." : "Tap the button to authorize in your wallet app" })
4140
+ /* @__PURE__ */ jsxRuntime.jsx("p", { style: hintStyle3(tokens.textMuted), children: loading ? "Preparing authorization..." : "If your wallet didn't open automatically, tap the button above" })
3876
4141
  ] }),
3877
4142
  children: [
3878
4143
  /* @__PURE__ */ jsxRuntime.jsx(ScreenHeader, { right: /* @__PURE__ */ jsxRuntime.jsx(SettingsMenu, { onLogout }) }),
3879
4144
  /* @__PURE__ */ jsxRuntime.jsxs("div", { style: contentStyle6, children: [
3880
4145
  logoSrc ? /* @__PURE__ */ jsxRuntime.jsx("img", { src: logoSrc, alt: displayName, style: logoStyle }) : /* @__PURE__ */ jsxRuntime.jsx(Spinner, { size: 48 }),
3881
- /* @__PURE__ */ jsxRuntime.jsx("h2", { style: headingStyle8(tokens.text), children: loading ? "Connecting..." : `Open ${displayName}` }),
3882
- /* @__PURE__ */ jsxRuntime.jsx("p", { style: subtitleStyle8(tokens.textSecondary), children: loading ? "Creating transfer and preparing your wallet link..." : `Continue in ${displayName} to authorize this connection.` }),
4146
+ /* @__PURE__ */ jsxRuntime.jsx("h2", { style: headingStyle9(tokens.text), children: loading ? "Connecting..." : `Open ${displayName}` }),
4147
+ /* @__PURE__ */ jsxRuntime.jsx("p", { style: subtitleStyle9(tokens.textSecondary), children: loading ? "Creating transfer and preparing your wallet link..." : `Continue in ${displayName} to authorize this connection.` }),
3883
4148
  !loading && /* @__PURE__ */ jsxRuntime.jsxs("div", { style: waitingBadgeStyle(tokens), children: [
3884
4149
  /* @__PURE__ */ jsxRuntime.jsx(Spinner, { size: 14 }),
3885
4150
  /* @__PURE__ */ jsxRuntime.jsx("span", { children: "Waiting for authorization..." })
@@ -3904,14 +4169,14 @@ var logoStyle = {
3904
4169
  borderRadius: 14,
3905
4170
  objectFit: "contain"
3906
4171
  };
3907
- var headingStyle8 = (color) => ({
4172
+ var headingStyle9 = (color) => ({
3908
4173
  fontSize: "1.45rem",
3909
4174
  fontWeight: 700,
3910
4175
  letterSpacing: "-0.02em",
3911
4176
  color,
3912
4177
  margin: "20px 0 8px"
3913
4178
  });
3914
- var subtitleStyle8 = (color) => ({
4179
+ var subtitleStyle9 = (color) => ({
3915
4180
  fontSize: "0.9rem",
3916
4181
  color,
3917
4182
  margin: "0 0 24px",
@@ -3935,6 +4200,98 @@ var hintStyle3 = (color) => ({
3935
4200
  color,
3936
4201
  margin: "8px 0 0"
3937
4202
  });
4203
+ function ConfirmSignScreen({
4204
+ walletName,
4205
+ signing,
4206
+ error,
4207
+ onSign,
4208
+ onLogout
4209
+ }) {
4210
+ const { tokens } = useSwypeConfig();
4211
+ const displayName = walletName ?? "your wallet";
4212
+ const logoSrc = walletName ? KNOWN_LOGOS[walletName.toLowerCase()] : void 0;
4213
+ return /* @__PURE__ */ jsxRuntime.jsxs(
4214
+ ScreenLayout,
4215
+ {
4216
+ footer: /* @__PURE__ */ jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [
4217
+ /* @__PURE__ */ jsxRuntime.jsx(PrimaryButton, { onClick: onSign, disabled: signing, children: signing ? "Confirming..." : "Confirm payment" }),
4218
+ error && /* @__PURE__ */ jsxRuntime.jsx("p", { style: errorStyle2(tokens.textMuted), children: error }),
4219
+ !error && /* @__PURE__ */ jsxRuntime.jsx("p", { style: hintStyle4(tokens.textMuted), children: "You may be prompted for biometric verification" })
4220
+ ] }),
4221
+ children: [
4222
+ /* @__PURE__ */ jsxRuntime.jsx(ScreenHeader, { right: /* @__PURE__ */ jsxRuntime.jsx(SettingsMenu, { onLogout }) }),
4223
+ /* @__PURE__ */ jsxRuntime.jsxs("div", { style: contentStyle7, children: [
4224
+ logoSrc ? /* @__PURE__ */ jsxRuntime.jsx("img", { src: logoSrc, alt: displayName, style: logoStyle2 }) : /* @__PURE__ */ jsxRuntime.jsx(Spinner, { size: 48 }),
4225
+ /* @__PURE__ */ jsxRuntime.jsx("h2", { style: headingStyle10(tokens.text), children: "Wallet authorized" }),
4226
+ /* @__PURE__ */ jsxRuntime.jsxs("p", { style: subtitleStyle10(tokens.textSecondary), children: [
4227
+ displayName,
4228
+ " approved the connection. Tap below to confirm your payment."
4229
+ ] }),
4230
+ /* @__PURE__ */ jsxRuntime.jsxs("div", { style: successBadgeStyle(tokens), children: [
4231
+ /* @__PURE__ */ jsxRuntime.jsx("span", { style: checkmarkStyle, children: "\u2713" }),
4232
+ /* @__PURE__ */ jsxRuntime.jsx("span", { children: "Authorization complete" })
4233
+ ] })
4234
+ ] })
4235
+ ]
4236
+ }
4237
+ );
4238
+ }
4239
+ var contentStyle7 = {
4240
+ flex: 1,
4241
+ display: "flex",
4242
+ flexDirection: "column",
4243
+ alignItems: "center",
4244
+ justifyContent: "center",
4245
+ textAlign: "center",
4246
+ padding: "0 24px"
4247
+ };
4248
+ var logoStyle2 = {
4249
+ width: 56,
4250
+ height: 56,
4251
+ borderRadius: 14,
4252
+ objectFit: "contain"
4253
+ };
4254
+ var headingStyle10 = (color) => ({
4255
+ fontSize: "1.45rem",
4256
+ fontWeight: 700,
4257
+ letterSpacing: "-0.02em",
4258
+ color,
4259
+ margin: "20px 0 8px"
4260
+ });
4261
+ var subtitleStyle10 = (color) => ({
4262
+ fontSize: "0.9rem",
4263
+ color,
4264
+ margin: "0 0 24px",
4265
+ lineHeight: 1.5,
4266
+ maxWidth: 280
4267
+ });
4268
+ var successBadgeStyle = (tokens) => ({
4269
+ display: "inline-flex",
4270
+ alignItems: "center",
4271
+ gap: 8,
4272
+ padding: "8px 16px",
4273
+ borderRadius: 20,
4274
+ background: tokens.bgInput,
4275
+ border: `1px solid ${tokens.border}`,
4276
+ color: "#22c55e",
4277
+ fontSize: "0.82rem"
4278
+ });
4279
+ var checkmarkStyle = {
4280
+ fontWeight: 700,
4281
+ fontSize: "0.9rem"
4282
+ };
4283
+ var hintStyle4 = (color) => ({
4284
+ textAlign: "center",
4285
+ fontSize: "0.82rem",
4286
+ color,
4287
+ margin: "8px 0 0"
4288
+ });
4289
+ var errorStyle2 = (color) => ({
4290
+ textAlign: "center",
4291
+ fontSize: "0.82rem",
4292
+ color: "#ef4444",
4293
+ margin: "8px 0 0"
4294
+ });
3938
4295
  var PaymentErrorBoundary = class extends react.Component {
3939
4296
  constructor(props) {
3940
4297
  super(props);
@@ -3960,7 +4317,7 @@ var PaymentErrorBoundary = class extends react.Component {
3960
4317
  /* @__PURE__ */ jsxRuntime.jsx("path", { d: "M12 8v5", stroke: "#ef4444", strokeWidth: "1.5", strokeLinecap: "round" }),
3961
4318
  /* @__PURE__ */ jsxRuntime.jsx("circle", { cx: "12", cy: "16", r: "0.75", fill: "#ef4444" })
3962
4319
  ] }) }),
3963
- /* @__PURE__ */ jsxRuntime.jsx("h2", { style: headingStyle9, children: "Something went wrong" }),
4320
+ /* @__PURE__ */ jsxRuntime.jsx("h2", { style: headingStyle11, children: "Something went wrong" }),
3964
4321
  /* @__PURE__ */ jsxRuntime.jsx("p", { style: messageStyle, children: "An unexpected error occurred. Please try again." }),
3965
4322
  /* @__PURE__ */ jsxRuntime.jsx("button", { type: "button", onClick: this.handleReset, style: buttonStyle3, children: "Try again" })
3966
4323
  ] });
@@ -3980,7 +4337,7 @@ var containerStyle8 = {
3980
4337
  var iconStyle4 = {
3981
4338
  marginBottom: 20
3982
4339
  };
3983
- var headingStyle9 = {
4340
+ var headingStyle11 = {
3984
4341
  fontSize: "1.25rem",
3985
4342
  fontWeight: 700,
3986
4343
  color: "#1a1a1a",
@@ -4003,13 +4360,6 @@ var buttonStyle3 = {
4003
4360
  fontFamily: "inherit",
4004
4361
  cursor: "pointer"
4005
4362
  };
4006
- function isInIframe() {
4007
- try {
4008
- return typeof window !== "undefined" && window !== window.top;
4009
- } catch {
4010
- return true;
4011
- }
4012
- }
4013
4363
  var ACTIVE_CREDENTIAL_STORAGE_KEY = "swype_active_credential_id";
4014
4364
  var MOBILE_FLOW_STORAGE_KEY = "swype_mobile_flow";
4015
4365
  var MIN_SEND_AMOUNT_USD = 0.25;
@@ -4356,7 +4706,7 @@ function SwypePaymentInner({
4356
4706
  if (defaults) {
4357
4707
  setSelectedAccountId(defaults.accountId);
4358
4708
  setSelectedWalletId(defaults.walletId);
4359
- } else if (prov.length > 0) {
4709
+ } else if (prov.length > 0 && !connectingNewAccount) {
4360
4710
  setSelectedProviderId(prov[0].id);
4361
4711
  }
4362
4712
  const hasActiveWallet = accts.some(
@@ -4439,23 +4789,8 @@ function SwypePaymentInner({
4439
4789
  });
4440
4790
  return;
4441
4791
  }
4442
- if (transferSigning.signing) return;
4443
- if (mobileSigningTransferIdRef.current === polledTransfer.id) return;
4444
- mobileSigningTransferIdRef.current = polledTransfer.id;
4445
- const sign = async () => {
4446
- try {
4447
- const signedTransfer = await transferSigning.signTransfer(polledTransfer.id);
4448
- setTransfer(signedTransfer);
4449
- clearMobileFlowState();
4450
- setStep("processing");
4451
- } catch (err) {
4452
- mobileSigningTransferIdRef.current = null;
4453
- const msg = err instanceof Error ? err.message : "Failed to sign transfer";
4454
- setError(msg);
4455
- onError?.(msg);
4456
- }
4457
- };
4458
- void sign();
4792
+ setTransfer(polledTransfer);
4793
+ setStep("confirm-sign");
4459
4794
  }, [mobileFlow, polling.transfer, polling.stopPolling, transferSigning, onError, reloadAccounts]);
4460
4795
  react.useEffect(() => {
4461
4796
  if (!mobileFlow) return;
@@ -4645,12 +4980,10 @@ function SwypePaymentInner({
4645
4980
  persistMobileFlowState({
4646
4981
  transferId: t.id,
4647
4982
  deeplinkUri: uri,
4648
- providerId: selectedProviderId,
4983
+ providerId: sourceOverrides?.sourceType === "providerId" ? sourceOverrides.sourceId : selectedProviderId,
4649
4984
  isSetup: mobileSetupFlowRef.current
4650
4985
  });
4651
- if (!isInIframe()) {
4652
- window.location.href = uri;
4653
- }
4986
+ window.location.href = uri;
4654
4987
  return;
4655
4988
  } else {
4656
4989
  await authExecutor.executeSession(t);
@@ -4806,6 +5139,20 @@ function SwypePaymentInner({
4806
5139
  setDeeplinkUri(null);
4807
5140
  resetHeadlessLogin();
4808
5141
  }, [logout, polling, depositAmount, resetHeadlessLogin]);
5142
+ const handleConfirmSign = react.useCallback(async () => {
5143
+ const t = transfer ?? polling.transfer;
5144
+ if (!t) return;
5145
+ try {
5146
+ const signedTransfer = await transferSigning.signTransfer(t.id);
5147
+ setTransfer(signedTransfer);
5148
+ clearMobileFlowState();
5149
+ setStep("processing");
5150
+ } catch (err) {
5151
+ const msg = err instanceof Error ? err.message : "Failed to sign transfer";
5152
+ setError(msg);
5153
+ onError?.(msg);
5154
+ }
5155
+ }, [transfer, polling.transfer, transferSigning, onError]);
4809
5156
  if (!ready) {
4810
5157
  return /* @__PURE__ */ jsxRuntime.jsx(ScreenLayout, { children: /* @__PURE__ */ jsxRuntime.jsx("div", { style: { textAlign: "center", padding: "48px 0", flex: 1, display: "flex", alignItems: "center", justifyContent: "center" }, children: /* @__PURE__ */ jsxRuntime.jsx(Spinner, { label: "Initializing..." }) }) });
4811
5158
  }
@@ -4887,6 +5234,19 @@ function SwypePaymentInner({
4887
5234
  }
4888
5235
  );
4889
5236
  }
5237
+ if (step === "confirm-sign") {
5238
+ const providerName = providers.find((p) => p.id === selectedProviderId)?.name ?? null;
5239
+ return /* @__PURE__ */ jsxRuntime.jsx(
5240
+ ConfirmSignScreen,
5241
+ {
5242
+ walletName: providerName,
5243
+ signing: transferSigning.signing,
5244
+ error: error || transferSigning.error,
5245
+ onSign: handleConfirmSign,
5246
+ onLogout: handleLogout
5247
+ }
5248
+ );
5249
+ }
4890
5250
  if (step === "deposit") {
4891
5251
  if (loadingData) {
4892
5252
  return /* @__PURE__ */ jsxRuntime.jsx(ScreenLayout, { children: /* @__PURE__ */ jsxRuntime.jsx("div", { style: { textAlign: "center", padding: "48px 0", flex: 1, display: "flex", alignItems: "center", justifyContent: "center" }, children: /* @__PURE__ */ jsxRuntime.jsx(Spinner, { label: "Loading..." }) }) });
@@ -4991,6 +5351,8 @@ function SwypePaymentInner({
4991
5351
  return null;
4992
5352
  }
4993
5353
 
5354
+ exports.AdvancedSourceScreen = AdvancedSourceScreen;
5355
+ exports.CreatePasskeyScreen = CreatePasskeyScreen;
4994
5356
  exports.IconCircle = IconCircle;
4995
5357
  exports.OutlineButton = OutlineButton;
4996
5358
  exports.PasskeyIframeBlockedError = PasskeyIframeBlockedError;