@dintero/checkout-web-sdk 0.5.10 → 0.6.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.
- package/README.md +4 -2
- package/coverage/{Chrome Headless 117.0.5938.92 (Linux x86_64) → Chrome Headless 117.0.5938.149 (Linux x86_64)}/html/checkout.ts.html +91 -4
- package/coverage/{Chrome Headless 117.0.5938.92 (Linux x86_64) → Chrome Headless 117.0.5938.149 (Linux x86_64)}/html/createIframeAsync.ts.html +15 -15
- package/coverage/{Chrome Headless 117.0.5938.92 (Linux x86_64) → Chrome Headless 117.0.5938.149 (Linux x86_64)}/html/index.html +88 -43
- package/coverage/{Chrome Headless 117.0.5938.92 (Linux x86_64) → Chrome Headless 117.0.5938.149 (Linux x86_64)}/html/index.ts.html +1085 -95
- package/coverage/Chrome Headless 117.0.5938.149 (Linux x86_64)/html/popOut.ts.html +377 -0
- package/coverage/Chrome Headless 117.0.5938.149 (Linux x86_64)/html/popOutBackdrop.ts.html +1046 -0
- package/coverage/Chrome Headless 117.0.5938.149 (Linux x86_64)/html/popOutButton.ts.html +374 -0
- package/coverage/{Chrome Headless 117.0.5938.92 (Linux x86_64) → Chrome Headless 117.0.5938.149 (Linux x86_64)}/html/subscribe.ts.html +218 -29
- package/coverage/Chrome Headless 117.0.5938.149 (Linux x86_64)/html/url.ts.html +284 -0
- package/dist/declarations/src/checkout.d.ts +29 -1
- package/dist/declarations/src/index.d.ts +17 -1
- package/dist/declarations/src/subscribe.d.ts +62 -0
- package/dist/dintero-checkout-web-sdk.cjs.dev.js +917 -53
- package/dist/dintero-checkout-web-sdk.cjs.prod.js +917 -53
- package/dist/dintero-checkout-web-sdk.esm.js +917 -53
- package/dist/dintero-checkout-web-sdk.umd.min.js +1 -1
- package/dist/dintero-checkout-web-sdk.umd.min.js.map +1 -1
- package/package.json +1 -1
- package/coverage/Chrome Headless 117.0.5938.92 (Linux x86_64)/html/url.ts.html +0 -185
- /package/coverage/{Chrome Headless 117.0.5938.92 (Linux x86_64) → Chrome Headless 117.0.5938.149 (Linux x86_64)}/html/base.css +0 -0
- /package/coverage/{Chrome Headless 117.0.5938.92 (Linux x86_64) → Chrome Headless 117.0.5938.149 (Linux x86_64)}/html/block-navigation.js +0 -0
- /package/coverage/{Chrome Headless 117.0.5938.92 (Linux x86_64) → Chrome Headless 117.0.5938.149 (Linux x86_64)}/html/favicon.png +0 -0
- /package/coverage/{Chrome Headless 117.0.5938.92 (Linux x86_64) → Chrome Headless 117.0.5938.149 (Linux x86_64)}/html/prettify.css +0 -0
- /package/coverage/{Chrome Headless 117.0.5938.92 (Linux x86_64) → Chrome Headless 117.0.5938.149 (Linux x86_64)}/html/prettify.js +0 -0
- /package/coverage/{Chrome Headless 117.0.5938.92 (Linux x86_64) → Chrome Headless 117.0.5938.149 (Linux x86_64)}/html/sort-arrow-sprite.png +0 -0
- /package/coverage/{Chrome Headless 117.0.5938.92 (Linux x86_64) → Chrome Headless 117.0.5938.149 (Linux x86_64)}/html/sorter.js +0 -0
|
@@ -0,0 +1,284 @@
|
|
|
1
|
+
|
|
2
|
+
<!doctype html>
|
|
3
|
+
<html lang="en">
|
|
4
|
+
|
|
5
|
+
<head>
|
|
6
|
+
<title>Code coverage report for url.ts</title>
|
|
7
|
+
<meta charset="utf-8" />
|
|
8
|
+
<link rel="stylesheet" href="prettify.css" />
|
|
9
|
+
<link rel="stylesheet" href="base.css" />
|
|
10
|
+
<link rel="shortcut icon" type="image/x-icon" href="favicon.png" />
|
|
11
|
+
<meta name="viewport" content="width=device-width, initial-scale=1" />
|
|
12
|
+
<style type='text/css'>
|
|
13
|
+
.coverage-summary .sorter {
|
|
14
|
+
background-image: url(sort-arrow-sprite.png);
|
|
15
|
+
}
|
|
16
|
+
</style>
|
|
17
|
+
</head>
|
|
18
|
+
|
|
19
|
+
<body>
|
|
20
|
+
<div class='wrapper'>
|
|
21
|
+
<div class='pad1'>
|
|
22
|
+
<h1><a href="index.html">All files</a> url.ts</h1>
|
|
23
|
+
<div class='clearfix'>
|
|
24
|
+
|
|
25
|
+
<div class='fl pad1y space-right2'>
|
|
26
|
+
<span class="strong">46.34% </span>
|
|
27
|
+
<span class="quiet">Statements</span>
|
|
28
|
+
<span class='fraction'>19/41</span>
|
|
29
|
+
</div>
|
|
30
|
+
|
|
31
|
+
|
|
32
|
+
<div class='fl pad1y space-right2'>
|
|
33
|
+
<span class="strong">38.89% </span>
|
|
34
|
+
<span class="quiet">Branches</span>
|
|
35
|
+
<span class='fraction'>7/18</span>
|
|
36
|
+
</div>
|
|
37
|
+
|
|
38
|
+
|
|
39
|
+
<div class='fl pad1y space-right2'>
|
|
40
|
+
<span class="strong">25% </span>
|
|
41
|
+
<span class="quiet">Functions</span>
|
|
42
|
+
<span class='fraction'>1/4</span>
|
|
43
|
+
</div>
|
|
44
|
+
|
|
45
|
+
|
|
46
|
+
<div class='fl pad1y space-right2'>
|
|
47
|
+
<span class="strong">48.48% </span>
|
|
48
|
+
<span class="quiet">Lines</span>
|
|
49
|
+
<span class='fraction'>16/33</span>
|
|
50
|
+
</div>
|
|
51
|
+
|
|
52
|
+
|
|
53
|
+
</div>
|
|
54
|
+
<p class="quiet">
|
|
55
|
+
Press <em>n</em> or <em>j</em> to go to the next uncovered block, <em>b</em>, <em>p</em> or <em>k</em> for the previous block.
|
|
56
|
+
</p>
|
|
57
|
+
</div>
|
|
58
|
+
<div class='status-line low'></div>
|
|
59
|
+
<pre><table class="coverage">
|
|
60
|
+
<tr><td class="line-count quiet"><a name='L1'></a><a href='#L1'>1</a>
|
|
61
|
+
<a name='L2'></a><a href='#L2'>2</a>
|
|
62
|
+
<a name='L3'></a><a href='#L3'>3</a>
|
|
63
|
+
<a name='L4'></a><a href='#L4'>4</a>
|
|
64
|
+
<a name='L5'></a><a href='#L5'>5</a>
|
|
65
|
+
<a name='L6'></a><a href='#L6'>6</a>
|
|
66
|
+
<a name='L7'></a><a href='#L7'>7</a>
|
|
67
|
+
<a name='L8'></a><a href='#L8'>8</a>
|
|
68
|
+
<a name='L9'></a><a href='#L9'>9</a>
|
|
69
|
+
<a name='L10'></a><a href='#L10'>10</a>
|
|
70
|
+
<a name='L11'></a><a href='#L11'>11</a>
|
|
71
|
+
<a name='L12'></a><a href='#L12'>12</a>
|
|
72
|
+
<a name='L13'></a><a href='#L13'>13</a>
|
|
73
|
+
<a name='L14'></a><a href='#L14'>14</a>
|
|
74
|
+
<a name='L15'></a><a href='#L15'>15</a>
|
|
75
|
+
<a name='L16'></a><a href='#L16'>16</a>
|
|
76
|
+
<a name='L17'></a><a href='#L17'>17</a>
|
|
77
|
+
<a name='L18'></a><a href='#L18'>18</a>
|
|
78
|
+
<a name='L19'></a><a href='#L19'>19</a>
|
|
79
|
+
<a name='L20'></a><a href='#L20'>20</a>
|
|
80
|
+
<a name='L21'></a><a href='#L21'>21</a>
|
|
81
|
+
<a name='L22'></a><a href='#L22'>22</a>
|
|
82
|
+
<a name='L23'></a><a href='#L23'>23</a>
|
|
83
|
+
<a name='L24'></a><a href='#L24'>24</a>
|
|
84
|
+
<a name='L25'></a><a href='#L25'>25</a>
|
|
85
|
+
<a name='L26'></a><a href='#L26'>26</a>
|
|
86
|
+
<a name='L27'></a><a href='#L27'>27</a>
|
|
87
|
+
<a name='L28'></a><a href='#L28'>28</a>
|
|
88
|
+
<a name='L29'></a><a href='#L29'>29</a>
|
|
89
|
+
<a name='L30'></a><a href='#L30'>30</a>
|
|
90
|
+
<a name='L31'></a><a href='#L31'>31</a>
|
|
91
|
+
<a name='L32'></a><a href='#L32'>32</a>
|
|
92
|
+
<a name='L33'></a><a href='#L33'>33</a>
|
|
93
|
+
<a name='L34'></a><a href='#L34'>34</a>
|
|
94
|
+
<a name='L35'></a><a href='#L35'>35</a>
|
|
95
|
+
<a name='L36'></a><a href='#L36'>36</a>
|
|
96
|
+
<a name='L37'></a><a href='#L37'>37</a>
|
|
97
|
+
<a name='L38'></a><a href='#L38'>38</a>
|
|
98
|
+
<a name='L39'></a><a href='#L39'>39</a>
|
|
99
|
+
<a name='L40'></a><a href='#L40'>40</a>
|
|
100
|
+
<a name='L41'></a><a href='#L41'>41</a>
|
|
101
|
+
<a name='L42'></a><a href='#L42'>42</a>
|
|
102
|
+
<a name='L43'></a><a href='#L43'>43</a>
|
|
103
|
+
<a name='L44'></a><a href='#L44'>44</a>
|
|
104
|
+
<a name='L45'></a><a href='#L45'>45</a>
|
|
105
|
+
<a name='L46'></a><a href='#L46'>46</a>
|
|
106
|
+
<a name='L47'></a><a href='#L47'>47</a>
|
|
107
|
+
<a name='L48'></a><a href='#L48'>48</a>
|
|
108
|
+
<a name='L49'></a><a href='#L49'>49</a>
|
|
109
|
+
<a name='L50'></a><a href='#L50'>50</a>
|
|
110
|
+
<a name='L51'></a><a href='#L51'>51</a>
|
|
111
|
+
<a name='L52'></a><a href='#L52'>52</a>
|
|
112
|
+
<a name='L53'></a><a href='#L53'>53</a>
|
|
113
|
+
<a name='L54'></a><a href='#L54'>54</a>
|
|
114
|
+
<a name='L55'></a><a href='#L55'>55</a>
|
|
115
|
+
<a name='L56'></a><a href='#L56'>56</a>
|
|
116
|
+
<a name='L57'></a><a href='#L57'>57</a>
|
|
117
|
+
<a name='L58'></a><a href='#L58'>58</a>
|
|
118
|
+
<a name='L59'></a><a href='#L59'>59</a>
|
|
119
|
+
<a name='L60'></a><a href='#L60'>60</a>
|
|
120
|
+
<a name='L61'></a><a href='#L61'>61</a>
|
|
121
|
+
<a name='L62'></a><a href='#L62'>62</a>
|
|
122
|
+
<a name='L63'></a><a href='#L63'>63</a>
|
|
123
|
+
<a name='L64'></a><a href='#L64'>64</a>
|
|
124
|
+
<a name='L65'></a><a href='#L65'>65</a>
|
|
125
|
+
<a name='L66'></a><a href='#L66'>66</a>
|
|
126
|
+
<a name='L67'></a><a href='#L67'>67</a>
|
|
127
|
+
<a name='L68'></a><a href='#L68'>68</a>
|
|
128
|
+
<a name='L69'></a><a href='#L69'>69</a></td><td class="line-coverage quiet"><span class="cline-any cline-yes">1x</span>
|
|
129
|
+
<span class="cline-any cline-neutral"> </span>
|
|
130
|
+
<span class="cline-any cline-neutral"> </span>
|
|
131
|
+
<span class="cline-any cline-neutral"> </span>
|
|
132
|
+
<span class="cline-any cline-neutral"> </span>
|
|
133
|
+
<span class="cline-any cline-yes">1x</span>
|
|
134
|
+
<span class="cline-any cline-no"> </span>
|
|
135
|
+
<span class="cline-any cline-neutral"> </span>
|
|
136
|
+
<span class="cline-any cline-neutral"> </span>
|
|
137
|
+
<span class="cline-any cline-neutral"> </span>
|
|
138
|
+
<span class="cline-any cline-neutral"> </span>
|
|
139
|
+
<span class="cline-any cline-neutral"> </span>
|
|
140
|
+
<span class="cline-any cline-neutral"> </span>
|
|
141
|
+
<span class="cline-any cline-neutral"> </span>
|
|
142
|
+
<span class="cline-any cline-neutral"> </span>
|
|
143
|
+
<span class="cline-any cline-neutral"> </span>
|
|
144
|
+
<span class="cline-any cline-neutral"> </span>
|
|
145
|
+
<span class="cline-any cline-neutral"> </span>
|
|
146
|
+
<span class="cline-any cline-neutral"> </span>
|
|
147
|
+
<span class="cline-any cline-neutral"> </span>
|
|
148
|
+
<span class="cline-any cline-neutral"> </span>
|
|
149
|
+
<span class="cline-any cline-neutral"> </span>
|
|
150
|
+
<span class="cline-any cline-yes">1x</span>
|
|
151
|
+
<span class="cline-any cline-yes">12x</span>
|
|
152
|
+
<span class="cline-any cline-yes">2x</span>
|
|
153
|
+
<span class="cline-any cline-no"> </span>
|
|
154
|
+
<span class="cline-any cline-neutral"> </span>
|
|
155
|
+
<span class="cline-any cline-yes">2x</span>
|
|
156
|
+
<span class="cline-any cline-yes">2x</span>
|
|
157
|
+
<span class="cline-any cline-yes">2x</span>
|
|
158
|
+
<span class="cline-any cline-no"> </span>
|
|
159
|
+
<span class="cline-any cline-neutral"> </span>
|
|
160
|
+
<span class="cline-any cline-yes">2x</span>
|
|
161
|
+
<span class="cline-any cline-yes">1x</span>
|
|
162
|
+
<span class="cline-any cline-neutral"> </span>
|
|
163
|
+
<span class="cline-any cline-yes">2x</span>
|
|
164
|
+
<span class="cline-any cline-no"> </span>
|
|
165
|
+
<span class="cline-any cline-neutral"> </span>
|
|
166
|
+
<span class="cline-any cline-yes">2x</span>
|
|
167
|
+
<span class="cline-any cline-no"> </span>
|
|
168
|
+
<span class="cline-any cline-neutral"> </span>
|
|
169
|
+
<span class="cline-any cline-yes">2x</span>
|
|
170
|
+
<span class="cline-any cline-neutral"> </span>
|
|
171
|
+
<span class="cline-any cline-yes">2x</span>
|
|
172
|
+
<span class="cline-any cline-neutral"> </span>
|
|
173
|
+
<span class="cline-any cline-neutral"> </span>
|
|
174
|
+
<span class="cline-any cline-neutral"> </span>
|
|
175
|
+
<span class="cline-any cline-neutral"> </span>
|
|
176
|
+
<span class="cline-any cline-no"> </span>
|
|
177
|
+
<span class="cline-any cline-no"> </span>
|
|
178
|
+
<span class="cline-any cline-neutral"> </span>
|
|
179
|
+
<span class="cline-any cline-neutral"> </span>
|
|
180
|
+
<span class="cline-any cline-yes">1x</span>
|
|
181
|
+
<span class="cline-any cline-neutral"> </span>
|
|
182
|
+
<span class="cline-any cline-yes">1x</span>
|
|
183
|
+
<span class="cline-any cline-no"> </span>
|
|
184
|
+
<span class="cline-any cline-no"> </span>
|
|
185
|
+
<span class="cline-any cline-neutral"> </span>
|
|
186
|
+
<span class="cline-any cline-no"> </span>
|
|
187
|
+
<span class="cline-any cline-no"> </span>
|
|
188
|
+
<span class="cline-any cline-no"> </span>
|
|
189
|
+
<span class="cline-any cline-no"> </span>
|
|
190
|
+
<span class="cline-any cline-no"> </span>
|
|
191
|
+
<span class="cline-any cline-no"> </span>
|
|
192
|
+
<span class="cline-any cline-no"> </span>
|
|
193
|
+
<span class="cline-any cline-neutral"> </span>
|
|
194
|
+
<span class="cline-any cline-no"> </span>
|
|
195
|
+
<span class="cline-any cline-neutral"> </span>
|
|
196
|
+
<span class="cline-any cline-neutral"> </span></td><td class="text"><pre class="prettyprint lang-js">import pkg from "../package.json";
|
|
197
|
+
|
|
198
|
+
/**
|
|
199
|
+
* Wraps window.location.assign()
|
|
200
|
+
*/
|
|
201
|
+
export const windowLocationAssign = <span class="fstat-no" title="function not covered" >(u</span>rl: string) => {
|
|
202
|
+
<span class="cstat-no" title="statement not covered" > window.location.assign(url);</span>
|
|
203
|
+
};
|
|
204
|
+
|
|
205
|
+
/**
|
|
206
|
+
* Get the url for the session./yarn-error.log
|
|
207
|
+
.DS_Store
|
|
208
|
+
*/
|
|
209
|
+
export interface SessionUrlOptions {
|
|
210
|
+
sid: string;
|
|
211
|
+
endpoint: string;
|
|
212
|
+
language: string | undefined;
|
|
213
|
+
ui?: "fullscreen" | "inline";
|
|
214
|
+
shouldCallValidateSession: boolean;
|
|
215
|
+
popOut?: boolean
|
|
216
|
+
}
|
|
217
|
+
|
|
218
|
+
export const getSessionUrl = (options: SessionUrlOptions): string => {
|
|
219
|
+
const { sid, endpoint, language, ui, shouldCallValidateSession, popOut } = options;
|
|
220
|
+
<span class="missing-if-branch" title="if path not taken" >I</span>if (!endpoint) {
|
|
221
|
+
<span class="cstat-no" title="statement not covered" > throw new Error("Invalid endpoint");</span>
|
|
222
|
+
}
|
|
223
|
+
const params = new URLSearchParams();
|
|
224
|
+
params.append('sdk', pkg.version);
|
|
225
|
+
<span class="missing-if-branch" title="if path not taken" >I</span>if(ui){
|
|
226
|
+
<span class="cstat-no" title="statement not covered" > params.append('ui', ui);</span>
|
|
227
|
+
}
|
|
228
|
+
if(language){
|
|
229
|
+
params.append('language', language);
|
|
230
|
+
}
|
|
231
|
+
<span class="missing-if-branch" title="if path not taken" >I</span>if(shouldCallValidateSession){
|
|
232
|
+
<span class="cstat-no" title="statement not covered" > params.append('client_side_validation', 'true');</span>
|
|
233
|
+
}
|
|
234
|
+
<span class="missing-if-branch" title="if path not taken" >I</span>if(popOut) {
|
|
235
|
+
<span class="cstat-no" title="statement not covered" > params.append('role', 'pop_out_launcher');</span>
|
|
236
|
+
}
|
|
237
|
+
<span class="missing-if-branch" title="else path not taken" >E</span>if (endpoint === "https://checkout.dintero.com") {
|
|
238
|
+
// Default endpoint will redirect via the view endpoint
|
|
239
|
+
return `${endpoint}/v1/view/${sid}?${params.toString()}`;
|
|
240
|
+
}
|
|
241
|
+
// When a custom endpoint is set skip the view redirect endpoint since
|
|
242
|
+
// custom endpoints like localhost and PR builds does not support the
|
|
243
|
+
// serverside view flow.
|
|
244
|
+
<span class="cstat-no" title="statement not covered" > params.append('sid', sid);</span>
|
|
245
|
+
<span class="cstat-no" title="statement not covered" > return `${endpoint}/?${params.toString()}`;</span>
|
|
246
|
+
};
|
|
247
|
+
|
|
248
|
+
const padTralingSlash = <span class="fstat-no" title="function not covered" >(e</span>ndpoint: string) => <span class="cstat-no" title="statement not covered" >endpoint.endsWith('/') ? endpoint : `${endpoint}/`;</span>
|
|
249
|
+
|
|
250
|
+
export const getPopOutUrl = <span class="fstat-no" title="function not covered" >({</span> sid<span class="cstat-no" title="statement not covered" >, e</span>ndpoint<span class="cstat-no" title="statement not covered" >, l</span>anguage<span class="cstat-no" title="statement not covered" >, s</span>houldCallValidateSession<span class="cstat-no" title="statement not covered" > }: SessionUrlOptions)</span> => {
|
|
251
|
+
<span class="cstat-no" title="statement not covered" > if (shouldCallValidateSession) {</span>
|
|
252
|
+
<span class="cstat-no" title="statement not covered" > return `${padTralingSlash(endpoint)}?loader=true`;</span>
|
|
253
|
+
}
|
|
254
|
+
const params = <span class="cstat-no" title="statement not covered" >new URLSearchParams();</span>
|
|
255
|
+
<span class="cstat-no" title="statement not covered" > params.append('ui', 'fullscreen');</span>
|
|
256
|
+
<span class="cstat-no" title="statement not covered" > params.append('role', 'pop_out_payment');</span>
|
|
257
|
+
<span class="cstat-no" title="statement not covered" > params.append('sid', sid);</span>
|
|
258
|
+
<span class="cstat-no" title="statement not covered" > params.append('sdk', pkg.version);</span>
|
|
259
|
+
<span class="cstat-no" title="statement not covered" > if (language) {</span>
|
|
260
|
+
<span class="cstat-no" title="statement not covered" > params.append('language', language);</span>
|
|
261
|
+
}
|
|
262
|
+
<span class="cstat-no" title="statement not covered" > return `${endpoint}/?${params.toString()}`;</span>
|
|
263
|
+
};
|
|
264
|
+
</pre></td></tr></table></pre>
|
|
265
|
+
|
|
266
|
+
<div class='push'></div><!-- for sticky footer -->
|
|
267
|
+
</div><!-- /wrapper -->
|
|
268
|
+
<div class='footer quiet pad2 space-top1 center small'>
|
|
269
|
+
Code coverage generated by
|
|
270
|
+
<a href="https://istanbul.js.org/" target="_blank">istanbul</a>
|
|
271
|
+
at Thu Oct 05 2023 22:10:07 GMT+0000 (Coordinated Universal Time)
|
|
272
|
+
</div>
|
|
273
|
+
</div>
|
|
274
|
+
<script src="prettify.js"></script>
|
|
275
|
+
<script>
|
|
276
|
+
window.onload = function () {
|
|
277
|
+
prettyPrint();
|
|
278
|
+
};
|
|
279
|
+
</script>
|
|
280
|
+
<script src="sorter.js"></script>
|
|
281
|
+
<script src="block-navigation.js"></script>
|
|
282
|
+
</body>
|
|
283
|
+
</html>
|
|
284
|
+
|
|
@@ -15,7 +15,9 @@ export declare enum CheckoutEvents {
|
|
|
15
15
|
export declare enum InternalCheckoutEvents {
|
|
16
16
|
HeightChanged = "HeightChanged",
|
|
17
17
|
LanguageChanged = "LanguageChanged",
|
|
18
|
-
ScrollToTop = "ScrollToTop"
|
|
18
|
+
ScrollToTop = "ScrollToTop",
|
|
19
|
+
ShowPopOutButton = "ShowPopOutButton",
|
|
20
|
+
HidePopOutButton = "HidePopOutButton"
|
|
19
21
|
}
|
|
20
22
|
export type SessionNotFound = {
|
|
21
23
|
type: CheckoutEvents.SessionNotFound;
|
|
@@ -49,6 +51,32 @@ export type SessionLocked = {
|
|
|
49
51
|
pay_lock_id: string;
|
|
50
52
|
callback: () => void;
|
|
51
53
|
};
|
|
54
|
+
export type ShowPopOutButton = {
|
|
55
|
+
type: 'ShowPopOutButton';
|
|
56
|
+
styles: {
|
|
57
|
+
font: string;
|
|
58
|
+
height: string;
|
|
59
|
+
color: string;
|
|
60
|
+
background: string;
|
|
61
|
+
textAlign: string;
|
|
62
|
+
padding: string;
|
|
63
|
+
margin: string;
|
|
64
|
+
border: string;
|
|
65
|
+
borderRadius: string;
|
|
66
|
+
cursor: string;
|
|
67
|
+
fontWeight: string;
|
|
68
|
+
lineHeight: string;
|
|
69
|
+
};
|
|
70
|
+
openLabel: string;
|
|
71
|
+
focusLabel: string;
|
|
72
|
+
closeLabel: string;
|
|
73
|
+
descriptionLabel: string;
|
|
74
|
+
top: string;
|
|
75
|
+
left: string;
|
|
76
|
+
right: string;
|
|
77
|
+
language: string;
|
|
78
|
+
disabled: 'true' | 'false';
|
|
79
|
+
};
|
|
52
80
|
export type SessionLockFailed = {
|
|
53
81
|
type: CheckoutEvents.SessionLockFailed;
|
|
54
82
|
};
|
|
@@ -1,5 +1,7 @@
|
|
|
1
1
|
import "native-promise-only";
|
|
2
|
-
import { SessionNotFound, SessionLoaded, SessionUpdated, SessionCancel, SessionPaymentOnHold, SessionPaymentAuthorized, SessionPaymentError, SessionLocked, SessionLockFailed, ActivePaymentProductType, ValidateSession, SessionValidationCallback, SessionEvent } from "./checkout.js";
|
|
2
|
+
import { CheckoutEvents, InternalCheckoutEvents, SessionNotFound, SessionLoaded, SessionUpdated, SessionCancel, SessionPaymentOnHold, SessionPaymentAuthorized, SessionPaymentError, SessionLocked, SessionLockFailed, ActivePaymentProductType, ValidateSession, SessionValidationCallback, SessionEvent } from "./checkout.js";
|
|
3
|
+
import { SubscriptionHandler } from "./subscribe.js";
|
|
4
|
+
import { Session } from "./session.js";
|
|
3
5
|
export interface DinteroCheckoutInstance {
|
|
4
6
|
/**
|
|
5
7
|
* Remove iframe and all event listeners.
|
|
@@ -11,6 +13,16 @@ export interface DinteroCheckoutInstance {
|
|
|
11
13
|
refreshSession: () => Promise<SessionEvent>;
|
|
12
14
|
setActivePaymentProductType: (paymentProductType: string) => void;
|
|
13
15
|
submitValidationResult: (result: SessionValidationCallback) => void;
|
|
16
|
+
options: InternalDinteroEmbedCheckoutOptions;
|
|
17
|
+
handlers: ({
|
|
18
|
+
handler: SubscriptionHandler;
|
|
19
|
+
eventTypes: InternalCheckoutEvents[];
|
|
20
|
+
} | {
|
|
21
|
+
handler: SubscriptionHandler;
|
|
22
|
+
eventTypes: CheckoutEvents[];
|
|
23
|
+
})[];
|
|
24
|
+
session: Session | undefined;
|
|
25
|
+
popOutWindow: Window | undefined;
|
|
14
26
|
}
|
|
15
27
|
export interface DinteroCheckoutOptions {
|
|
16
28
|
sid: string;
|
|
@@ -19,6 +31,7 @@ export interface DinteroCheckoutOptions {
|
|
|
19
31
|
}
|
|
20
32
|
export interface DinteroEmbedCheckoutOptions extends DinteroCheckoutOptions {
|
|
21
33
|
container: HTMLDivElement;
|
|
34
|
+
popOut?: boolean;
|
|
22
35
|
onPayment?: (event: SessionPaymentAuthorized | SessionPaymentOnHold, checkout: DinteroCheckoutInstance) => void;
|
|
23
36
|
/**
|
|
24
37
|
* @deprecated Since version 0.0.1. Will be deleted in version 1.0.0. Use onPayment instead.
|
|
@@ -33,6 +46,9 @@ export interface DinteroEmbedCheckoutOptions extends DinteroCheckoutOptions {
|
|
|
33
46
|
onActivePaymentType?: (event: ActivePaymentProductType, checkout: DinteroCheckoutInstance) => void;
|
|
34
47
|
onValidateSession?: (event: ValidateSession, checkout: DinteroCheckoutInstance, callback: (result: SessionValidationCallback) => void) => void;
|
|
35
48
|
}
|
|
49
|
+
interface InternalDinteroEmbedCheckoutOptions extends DinteroEmbedCheckoutOptions {
|
|
50
|
+
innerContainer: HTMLDivElement;
|
|
51
|
+
}
|
|
36
52
|
/**
|
|
37
53
|
* Show a dintero payment session in an embedded iframe.
|
|
38
54
|
*/
|
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
import { CheckoutEvents, InternalCheckoutEvents, SessionEvent, SessionValidationCallback } from "./checkout.js";
|
|
2
|
+
import { DinteroCheckoutInstance } from "./index.js";
|
|
3
|
+
/**
|
|
4
|
+
* Unsubscribe handler from event(s).
|
|
5
|
+
*/
|
|
6
|
+
export type SubscriptionHandler = (sessionEvent: SessionEvent, checkout: DinteroCheckoutInstance) => void;
|
|
7
|
+
interface SubscriptionOptions {
|
|
8
|
+
sid: string;
|
|
9
|
+
endpoint: string;
|
|
10
|
+
handler: SubscriptionHandler;
|
|
11
|
+
eventTypes: (CheckoutEvents | InternalCheckoutEvents)[];
|
|
12
|
+
checkout: DinteroCheckoutInstance;
|
|
13
|
+
source: Window;
|
|
14
|
+
}
|
|
15
|
+
export type Subscription = {
|
|
16
|
+
/**
|
|
17
|
+
* Unsubscribe handler from event(s).
|
|
18
|
+
*/
|
|
19
|
+
unsubscribe: () => void;
|
|
20
|
+
};
|
|
21
|
+
/**
|
|
22
|
+
* Post a SessionLock-event to the checkout iframe.
|
|
23
|
+
*/
|
|
24
|
+
export declare const postSessionLock: (iframe: HTMLIFrameElement, sid: string) => void;
|
|
25
|
+
/**
|
|
26
|
+
* Post the validation result to the checkout iframe
|
|
27
|
+
*/
|
|
28
|
+
export declare const postValidationResult: (iframe: HTMLIFrameElement, sid: string, result: SessionValidationCallback) => void;
|
|
29
|
+
/**
|
|
30
|
+
* Post RefreshSession-event to the checkout iframe.
|
|
31
|
+
*/
|
|
32
|
+
export declare const postSessionRefresh: (iframe: HTMLIFrameElement, sid: string) => void;
|
|
33
|
+
/**
|
|
34
|
+
* Post SetActivePaymentProductType-event to the checkout iframe.
|
|
35
|
+
*/
|
|
36
|
+
export declare const postActivePaymentProductType: (iframe: HTMLIFrameElement, sid: string, paymentProductType?: string) => void;
|
|
37
|
+
/**
|
|
38
|
+
* Post ClosePopOut-event to the checkout iframe.
|
|
39
|
+
*/
|
|
40
|
+
export declare const postValidatePopOutEvent: (iframe: HTMLIFrameElement, sid: string) => void;
|
|
41
|
+
/**
|
|
42
|
+
* Post OpenPopOutFailed-event to the checkout iframe.
|
|
43
|
+
*/
|
|
44
|
+
export declare const postOpenPopOutFailedEvent: (iframe: HTMLIFrameElement, sid: string) => void;
|
|
45
|
+
/**
|
|
46
|
+
* Post OpenedPopOut-event to the checkout iframe.
|
|
47
|
+
*/
|
|
48
|
+
export declare const postOpenPopOutEvent: (iframe: HTMLIFrameElement, sid: string) => void;
|
|
49
|
+
/**
|
|
50
|
+
* Post ClosePopOut-event to the checkout iframe.
|
|
51
|
+
*/
|
|
52
|
+
export declare const postClosePopOutEvent: (iframe: HTMLIFrameElement, sid: string) => void;
|
|
53
|
+
/**
|
|
54
|
+
* Post SetLanguage-event to the checkout iframe.
|
|
55
|
+
*/
|
|
56
|
+
export declare const postSetLanguage: (iframe: HTMLIFrameElement, sid: string, language: string) => void;
|
|
57
|
+
/**
|
|
58
|
+
* Subscribe to events from an iframe given a handler and a set
|
|
59
|
+
* of event types.
|
|
60
|
+
*/
|
|
61
|
+
export declare const subscribe: (options: SubscriptionOptions) => Subscription;
|
|
62
|
+
export {};
|