@rebilly/instruments 1.0.1-beta → 1.0.2-beta.10

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 (277) hide show
  1. package/.babelrc +23 -5
  2. package/.eslintrc.js +27 -0
  3. package/.prettierrc.js +11 -0
  4. package/CONTRIBUTING.md +4 -0
  5. package/README.md +361 -2
  6. package/dist/events/base-event.js +51 -37
  7. package/dist/events/events.spec.js +18 -0
  8. package/dist/events/index.js +11 -8
  9. package/dist/functions/destroy.js +27 -5
  10. package/dist/functions/destroy.spec.js +69 -0
  11. package/dist/functions/initialize.js +60 -41
  12. package/dist/functions/initialize.spec.js +13 -13
  13. package/dist/functions/mount/fetch-summary-data.js +46 -0
  14. package/dist/functions/mount/fetch-summary-data.spec.js +44 -0
  15. package/dist/functions/mount/index.js +346 -0
  16. package/dist/functions/mount/mount.spec.js +135 -0
  17. package/dist/functions/on.js +26 -18
  18. package/dist/functions/on.spec.js +45 -63
  19. package/dist/functions/purchase.js +41 -154
  20. package/dist/functions/purchase.spec.js +60 -76
  21. package/dist/functions/show.js +39 -43
  22. package/dist/functions/show.spec.js +57 -0
  23. package/dist/functions/update.js +60 -5
  24. package/dist/functions/update.spec.js +100 -0
  25. package/dist/i18n/en.json +19 -0
  26. package/dist/i18n/es.json +19 -0
  27. package/dist/i18n/i18n.spec.js +6 -23
  28. package/dist/i18n/index.js +44 -67
  29. package/dist/index.js +70 -71
  30. package/dist/index.spec.js +24 -44
  31. package/dist/loader/index.js +63 -62
  32. package/dist/loader/loader.spec.js +14 -11
  33. package/dist/storefront/index.js +28 -39
  34. package/dist/storefront/models/plan-model.js +37 -54
  35. package/dist/storefront/models/product-model.js +25 -36
  36. package/dist/storefront/models/ready-to-pay-model.js +38 -42
  37. package/dist/storefront/models/summary-model.js +72 -99
  38. package/dist/storefront/plans.js +37 -84
  39. package/dist/storefront/plans.spec.js +61 -151
  40. package/dist/storefront/products.js +35 -83
  41. package/dist/storefront/products.spec.js +60 -150
  42. package/dist/storefront/purchase.js +27 -64
  43. package/dist/storefront/purchase.spec.js +51 -87
  44. package/dist/storefront/ready-to-pay.js +45 -107
  45. package/dist/storefront/ready-to-pay.spec.js +72 -147
  46. package/dist/storefront/storefront.spec.js +6 -6
  47. package/dist/storefront/summary.js +37 -84
  48. package/dist/storefront/summary.spec.js +135 -240
  49. package/dist/style/base/__snapshots__/theme.spec.js.snap +52 -0
  50. package/dist/style/base/index.js +72 -0
  51. package/dist/style/base/theme.js +73 -0
  52. package/dist/style/base/theme.spec.js +30 -0
  53. package/dist/style/browserslist.js +8 -0
  54. package/dist/style/components/address.js +64 -0
  55. package/dist/style/components/button.js +61 -0
  56. package/dist/style/components/divider.js +48 -0
  57. package/dist/style/components/forms/checkbox.js +83 -0
  58. package/dist/style/components/forms/field.js +53 -0
  59. package/dist/style/components/forms/form.js +28 -0
  60. package/dist/style/components/forms/input.js +45 -0
  61. package/dist/style/components/forms/label.js +43 -0
  62. package/dist/style/components/forms/select.js +63 -0
  63. package/dist/style/components/forms/validation.js +34 -0
  64. package/dist/style/components/icons.js +22 -0
  65. package/dist/style/components/index.js +57 -0
  66. package/dist/style/components/loader.js +48 -0
  67. package/dist/style/components/methods.js +104 -0
  68. package/dist/style/components/overlay.js +33 -0
  69. package/dist/style/helpers/index.js +59 -0
  70. package/dist/style/index.js +48 -0
  71. package/dist/style/payment-instruments/content.js +17 -0
  72. package/dist/style/payment-instruments/index.js +20 -0
  73. package/dist/style/payment-instruments/payment-card.js +35 -0
  74. package/dist/style/utils/color-values.js +22 -0
  75. package/dist/style/vendor/framepay.js +34 -0
  76. package/dist/style/vendor/postmate.js +17 -0
  77. package/dist/style/views/confirmation.js +85 -0
  78. package/dist/style/views/index.js +29 -0
  79. package/dist/style/views/method-selector.js +20 -0
  80. package/dist/style/views/modal.js +93 -0
  81. package/dist/style/views/result.js +61 -0
  82. package/dist/style/views/summary.js +123 -0
  83. package/dist/utils/add-dom-element.js +12 -34
  84. package/dist/utils/format-currency.js +4 -4
  85. package/dist/utils/has-valid-css-selector.js +2 -2
  86. package/dist/utils/index.js +15 -31
  87. package/dist/utils/is-dom-element.js +1 -1
  88. package/dist/utils/process-property-as-dom-element.js +12 -17
  89. package/dist/utils/sleep.js +10 -0
  90. package/{src/components → dist/views}/__snapshots__/summary.spec.js.snap +7 -3
  91. package/dist/views/common/iframe/base-iframe.js +57 -0
  92. package/dist/views/common/iframe/event-listeners.js +50 -0
  93. package/dist/views/common/iframe/index.js +19 -0
  94. package/dist/views/common/iframe/method-iframe.js +33 -0
  95. package/dist/views/common/iframe/modal-iframe.js +38 -0
  96. package/dist/views/common/iframe/view-iframe.js +31 -0
  97. package/dist/views/common/render-utilities.js +11 -0
  98. package/dist/views/confirmation.js +82 -0
  99. package/dist/views/method-selector/__snapshots__/method-selector.spec.js.snap +3 -0
  100. package/dist/views/method-selector/express-methods/apple-pay.js +92 -0
  101. package/dist/views/method-selector/express-methods/google-pay.js +32 -0
  102. package/dist/views/method-selector/express-methods/paypal.js +19 -0
  103. package/dist/views/method-selector/generate-digital-wallet.js +59 -0
  104. package/dist/views/method-selector/generate-digital-wallet.spec.js +132 -0
  105. package/dist/views/method-selector/get-method-data.js +25 -0
  106. package/dist/views/method-selector/get-payment-methods.js +55 -0
  107. package/dist/views/method-selector/get-payment-methods.spec.js +44 -0
  108. package/dist/views/method-selector/index.js +133 -0
  109. package/dist/views/method-selector/method-selector.spec.js +139 -0
  110. package/dist/views/method-selector/mount-express-methods.js +69 -0
  111. package/dist/views/method-selector/mount-methods.js +78 -0
  112. package/dist/views/modal.js +83 -0
  113. package/dist/views/result.js +42 -0
  114. package/dist/views/summary.js +162 -0
  115. package/dist/views/summary.spec.js +148 -0
  116. package/package.json +12 -6
  117. package/src/events/base-event.js +35 -12
  118. package/src/events/events.spec.js +11 -0
  119. package/src/events/index.js +12 -6
  120. package/src/functions/destroy.js +22 -3
  121. package/src/functions/destroy.spec.js +63 -0
  122. package/src/functions/initialize.js +43 -20
  123. package/src/functions/initialize.spec.js +9 -7
  124. package/src/functions/mount/fetch-summary-data.js +29 -0
  125. package/src/functions/mount/fetch-summary-data.spec.js +41 -0
  126. package/src/functions/mount/index.js +312 -0
  127. package/src/functions/mount/mount.spec.js +171 -0
  128. package/src/functions/on.js +17 -14
  129. package/src/functions/on.spec.js +39 -29
  130. package/src/functions/purchase.js +24 -64
  131. package/src/functions/purchase.spec.js +19 -17
  132. package/src/functions/show.js +27 -7
  133. package/src/functions/show.spec.js +61 -0
  134. package/src/functions/update.js +50 -3
  135. package/src/functions/update.spec.js +107 -0
  136. package/src/i18n/i18n.spec.js +6 -4
  137. package/src/i18n/index.js +20 -12
  138. package/src/index.js +43 -49
  139. package/src/index.spec.js +11 -42
  140. package/src/loader/index.js +55 -39
  141. package/src/loader/loader.spec.js +30 -23
  142. package/src/storefront/index.js +9 -7
  143. package/src/storefront/models/plan-model.js +1 -1
  144. package/src/storefront/models/product-model.js +1 -1
  145. package/src/storefront/models/ready-to-pay-model.js +10 -4
  146. package/src/storefront/models/summary-model.js +8 -15
  147. package/src/storefront/plans.js +16 -12
  148. package/src/storefront/plans.spec.js +29 -37
  149. package/src/storefront/products.js +16 -12
  150. package/src/storefront/products.spec.js +28 -39
  151. package/src/storefront/purchase.js +8 -6
  152. package/src/storefront/purchase.spec.js +18 -17
  153. package/src/storefront/ready-to-pay.js +19 -13
  154. package/src/storefront/ready-to-pay.spec.js +41 -41
  155. package/src/storefront/storefront.spec.js +1 -1
  156. package/src/storefront/summary.js +14 -12
  157. package/src/storefront/summary.spec.js +37 -50
  158. package/src/style/base/__snapshots__/theme.spec.js.snap +52 -0
  159. package/src/style/base/index.js +63 -0
  160. package/src/style/base/theme.js +61 -0
  161. package/src/style/base/theme.spec.js +32 -0
  162. package/src/style/browserslist.js +1 -0
  163. package/src/style/components/address.js +55 -0
  164. package/src/style/components/button.js +54 -0
  165. package/src/style/components/divider.js +39 -0
  166. package/src/style/components/forms/checkbox.js +76 -0
  167. package/src/style/components/forms/field.js +44 -0
  168. package/src/style/components/forms/form.js +19 -0
  169. package/src/style/components/forms/input.js +36 -0
  170. package/src/style/components/forms/label.js +34 -0
  171. package/src/style/components/forms/select.js +54 -0
  172. package/src/style/components/forms/validation.js +25 -0
  173. package/src/style/components/icons.js +13 -0
  174. package/src/style/components/index.js +35 -0
  175. package/src/style/components/loader.js +41 -0
  176. package/src/style/components/methods.js +93 -0
  177. package/src/style/components/overlay.js +24 -0
  178. package/src/style/helpers/index.js +51 -0
  179. package/src/style/index.js +30 -0
  180. package/src/style/payment-instruments/content.js +8 -0
  181. package/src/style/payment-instruments/index.js +10 -0
  182. package/src/style/payment-instruments/payment-card.js +26 -0
  183. package/src/style/utils/color-values.js +9 -0
  184. package/src/style/vendor/framepay.js +25 -0
  185. package/src/style/vendor/postmate.js +8 -0
  186. package/src/style/views/confirmation.js +76 -0
  187. package/src/style/views/index.js +16 -0
  188. package/src/style/views/method-selector.js +11 -0
  189. package/src/style/views/modal.js +84 -0
  190. package/src/style/views/result.js +52 -0
  191. package/src/style/views/summary.js +114 -0
  192. package/src/utils/add-dom-element.js +12 -13
  193. package/src/utils/format-currency.js +4 -1
  194. package/src/utils/has-valid-css-selector.js +2 -2
  195. package/src/utils/index.js +2 -6
  196. package/src/utils/is-dom-element.js +1 -1
  197. package/src/utils/process-property-as-dom-element.js +27 -24
  198. package/src/utils/sleep.js +3 -0
  199. package/src/views/__snapshots__/summary.spec.js.snap +292 -0
  200. package/src/views/common/iframe/base-iframe.js +46 -0
  201. package/src/views/common/iframe/event-listeners.js +27 -0
  202. package/src/views/common/iframe/index.js +7 -0
  203. package/src/views/common/iframe/method-iframe.js +21 -0
  204. package/src/views/common/iframe/modal-iframe.js +27 -0
  205. package/src/views/common/iframe/view-iframe.js +18 -0
  206. package/src/views/common/render-utilities.js +4 -0
  207. package/src/views/confirmation.js +57 -0
  208. package/src/views/method-selector/__snapshots__/method-selector.spec.js.snap +3 -0
  209. package/src/views/method-selector/express-methods/apple-pay.js +78 -0
  210. package/src/views/method-selector/express-methods/google-pay.js +25 -0
  211. package/src/views/method-selector/express-methods/paypal.js +7 -0
  212. package/src/views/method-selector/generate-digital-wallet.js +44 -0
  213. package/src/views/method-selector/generate-digital-wallet.spec.js +131 -0
  214. package/src/{components/form → views/method-selector}/get-method-data.js +9 -5
  215. package/src/views/method-selector/get-payment-methods.js +40 -0
  216. package/src/views/method-selector/get-payment-methods.spec.js +40 -0
  217. package/src/views/method-selector/index.js +110 -0
  218. package/src/views/method-selector/method-selector.spec.js +146 -0
  219. package/src/views/method-selector/mount-express-methods.js +53 -0
  220. package/src/views/method-selector/mount-methods.js +71 -0
  221. package/src/views/modal.js +84 -0
  222. package/src/views/result.js +30 -0
  223. package/src/{components → views}/summary.js +90 -21
  224. package/src/views/summary.spec.js +170 -0
  225. package/tests/async-utilities.js +22 -0
  226. package/tests/mocks/rebilly-instruments-mock.js +105 -7
  227. package/dist/components/confirmation.js +0 -103
  228. package/dist/components/form/form.js +0 -110
  229. package/dist/components/form/form.spec.js +0 -135
  230. package/dist/components/form/get-method-data.js +0 -21
  231. package/dist/components/form/get-payment-methods.js +0 -42
  232. package/dist/components/form/method-selector.js +0 -61
  233. package/dist/components/form/mount-express-payment-methods.js +0 -102
  234. package/dist/components/form/process-digital-wallet-options.js +0 -20
  235. package/dist/components/form/zoid-helpers.js +0 -130
  236. package/dist/components/result.js +0 -66
  237. package/dist/components/summary.js +0 -60
  238. package/dist/components/summary.spec.js +0 -144
  239. package/dist/events/instrument-ready.js +0 -51
  240. package/dist/events/purchase-complete.js +0 -51
  241. package/dist/functions/mount.js +0 -311
  242. package/dist/functions/mount.spec.js +0 -203
  243. package/dist/styles/base-styles.js +0 -12
  244. package/dist/styles/flat-theme-object.js +0 -42
  245. package/dist/styles/framepay.js +0 -15
  246. package/dist/styles/main.js +0 -25
  247. package/dist/styles/payment-card.js +0 -12
  248. package/dist/styles/shade-tint-values-helper.js +0 -28
  249. package/dist/styles/style-variables.js +0 -43
  250. package/dist/utils/camel-case.js +0 -12
  251. package/dist/utils/kebab-case.js +0 -10
  252. package/dist/utils/un-kebab-case.js +0 -10
  253. package/src/components/confirmation.js +0 -77
  254. package/src/components/form/__snapshots__/form.spec.js.snap +0 -43
  255. package/src/components/form/form.js +0 -88
  256. package/src/components/form/form.spec.js +0 -109
  257. package/src/components/form/get-payment-methods.js +0 -32
  258. package/src/components/form/method-selector.js +0 -47
  259. package/src/components/form/mount-express-payment-methods.js +0 -84
  260. package/src/components/form/process-digital-wallet-options.js +0 -11
  261. package/src/components/form/zoid-helpers.js +0 -114
  262. package/src/components/result.js +0 -50
  263. package/src/components/summary.spec.js +0 -106
  264. package/src/events/instrument-ready.js +0 -11
  265. package/src/events/purchase-complete.js +0 -11
  266. package/src/functions/mount.js +0 -204
  267. package/src/functions/mount.spec.js +0 -172
  268. package/src/styles/base-styles.js +0 -741
  269. package/src/styles/flat-theme-object.js +0 -12
  270. package/src/styles/framepay.js +0 -30
  271. package/src/styles/main.js +0 -17
  272. package/src/styles/payment-card.js +0 -18
  273. package/src/styles/shade-tint-values-helper.js +0 -13
  274. package/src/styles/style-variables.js +0 -34
  275. package/src/utils/camel-case.js +0 -3
  276. package/src/utils/kebab-case.js +0 -3
  277. package/src/utils/un-kebab-case.js +0 -3
@@ -0,0 +1,34 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.validation = void 0;
7
+
8
+ // -----------------------------------------------------------------------------
9
+ // This file contains all styles related to the form validations.
10
+ // -----------------------------------------------------------------------------
11
+ const validation = theme => `
12
+ /**
13
+ * Validations
14
+ */
15
+ .rebilly-instruments-form-field.is-error .rebilly-instruments-form-field-input,
16
+ .rebilly-instruments-form-field.is-error .rebilly-instruments-form-field-select {
17
+ border-color: ${theme.color.errorText};
18
+ color: ${theme.color.errorText};
19
+ }
20
+
21
+ .rebilly-instruments-form-field-error-wrapper {
22
+ margin-top: ${theme.space.xxs};
23
+ margin-bottom: calc(${theme.space.xxs} + ${theme.space.s});
24
+ padding: 0;
25
+ list-style: none;
26
+ }
27
+
28
+ .rebilly-instruments-form-field-error-wrapper > li {
29
+ color: ${theme.color.errorText};
30
+ padding: 0;
31
+ }
32
+ `;
33
+
34
+ exports.validation = validation;
@@ -0,0 +1,22 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.icons = void 0;
7
+
8
+ // -----------------------------------------------------------------------------
9
+ // This file contains all styles related to the icons component.
10
+ // -----------------------------------------------------------------------------
11
+ const icons = theme => `
12
+ /**
13
+ * Icons
14
+ */
15
+ .rebilly-instruments-icon {
16
+ width: ${theme.typography.lineHeight};
17
+ height: ${theme.typography.lineHeight};
18
+ fill: ${theme.color.text};
19
+ }
20
+ `;
21
+
22
+ exports.icons = icons;
@@ -0,0 +1,57 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.components = void 0;
7
+
8
+ var _methods = require("./methods");
9
+
10
+ var _form = require("./forms/form");
11
+
12
+ var _checkbox = require("./forms/checkbox");
13
+
14
+ var _field = require("./forms/field");
15
+
16
+ var _input = require("./forms/input");
17
+
18
+ var _label = require("./forms/label");
19
+
20
+ var _select = require("./forms/select");
21
+
22
+ var _validation = require("./forms/validation");
23
+
24
+ var _button = require("./button");
25
+
26
+ var _divider = require("./divider");
27
+
28
+ var _loader = require("./loader");
29
+
30
+ var _icons = require("./icons");
31
+
32
+ var _address = require("./address");
33
+
34
+ var _overlay = require("./overlay");
35
+
36
+ // Order of components matters for style cascade
37
+ const components = theme => `
38
+ /* Components
39
+ ------------------------------------------------------------ */
40
+ ${(0, _methods.expressMethods)(theme)}
41
+ ${(0, _methods.methods)()}
42
+ ${(0, _form.form)(theme)}
43
+ ${(0, _field.field)(theme)}
44
+ ${(0, _input.input)(theme)}
45
+ ${(0, _select.select)(theme)}
46
+ ${(0, _label.label)(theme)}
47
+ ${(0, _checkbox.checkbox)(theme)}
48
+ ${(0, _validation.validation)(theme)}
49
+ ${(0, _button.button)(theme)}
50
+ ${(0, _divider.divider)(theme)}
51
+ ${(0, _loader.loader)(theme)}
52
+ ${(0, _icons.icons)(theme)}
53
+ ${(0, _address.address)(theme)}
54
+ ${(0, _overlay.overlay)(theme)}
55
+ `;
56
+
57
+ exports.components = components;
@@ -0,0 +1,48 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.loader = void 0;
7
+
8
+ // -----------------------------------------------------------------------------
9
+ // This file contains all styles related to the loader component.
10
+ // -----------------------------------------------------------------------------
11
+ const loader = theme => `
12
+ /**
13
+ * Loader
14
+ */
15
+ .rebilly-instruments-loader {
16
+ display: none;
17
+ position: absolute;
18
+ top: 0;
19
+ bottom: 0;
20
+ left: 0;
21
+ right: 0;
22
+ justify-content: center;
23
+ align-items: center;
24
+ background-color: ${theme.color.background};
25
+ z-index: 9000;
26
+ transition: all 200ms;
27
+ }
28
+
29
+ .rebilly-instruments-loader.is-active {
30
+ display: flex;
31
+ }
32
+
33
+ .rebilly-instruments-loader-spinner {
34
+ border: 4px solid ${theme.getComputed.color.primaryValues.tint(80).hexString()};
35
+ border-top: 4px solid ${theme.color.primary};
36
+ border-radius: 50%;
37
+ width: 40px;
38
+ height: 40px;
39
+ animation: spin 0.5s ease infinite;
40
+ }
41
+
42
+ @keyframes spin {
43
+ 0% { transform: rotate(0deg); }
44
+ 100% { transform: rotate(360deg); }
45
+ }
46
+ `;
47
+
48
+ exports.loader = loader;
@@ -0,0 +1,104 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.methods = exports.expressMethods = void 0;
7
+
8
+ // -----------------------------------------------------------------------------
9
+ // This file contains all styles related to the methods component.
10
+ // -----------------------------------------------------------------------------
11
+ const expressMethods = theme => `
12
+ /**
13
+ * Express methods
14
+ */
15
+
16
+ @keyframes rebillyExpressShine {
17
+ to {
18
+ background-position-x: -200%;
19
+ }
20
+ }
21
+
22
+ .rebilly-instruments-express-methods.is-compact {
23
+ border: 1px solid ${theme.getComputed.color.mutedBorder};
24
+ padding: calc(${theme.space.xs} + ${theme.space.s}) ${theme.space.s} ${theme.space.s};
25
+ border-radius: ${theme.borderRadius};
26
+ position: relative;
27
+ }
28
+
29
+ .rebilly-instruments-express-methods iframe {
30
+ display: block;
31
+ margin-bottom: 0;
32
+ }
33
+
34
+ .rebilly-instruments-express-methods .rebilly-instruments-express-methods-container > * {
35
+ border-radius: 6px;
36
+ margin-bottom: ${theme.space.xs};
37
+ background: linear-gradient(110deg, ${theme.getComputed.color.mutedBorder} 0%, ${theme.color.background} 25%, ${theme.getComputed.color.mutedBorder} 50%);
38
+ background-size: 200% 100%;
39
+ animation: 1.5s rebillyExpressShine linear infinite;
40
+ }
41
+ .rebilly-instruments-express-methods .rebilly-instruments-express-methods-container > *:last-child {
42
+ margin: 0;
43
+ }
44
+
45
+ .rebilly-instruments-express-methods.is-compact .rebilly-instruments-express-methods-container {
46
+ display: flex;
47
+ justify-content: center;
48
+ }
49
+
50
+ .rebilly-instruments-express-methods.is-compact .rebilly-instruments-express-methods-container > * {
51
+ flex: 1 1 0px;
52
+ max-width: 260px;
53
+ margin: 0 ${theme.space.xs};
54
+ }
55
+ .rebilly-instruments-express-methods.is-compact .rebilly-instruments-express-methods-container > *:first-child {
56
+ margin-left: 0;
57
+ }
58
+ .rebilly-instruments-express-methods.is-compact .rebilly-instruments-express-methods-container > *:last-child {
59
+ margin-right: 0;
60
+ }
61
+
62
+ .rebilly-instruments-express-methods .rebilly-instruments-express-methods-label {
63
+ display: none;
64
+ }
65
+ .rebilly-instruments-express-methods.is-compact .rebilly-instruments-express-methods-label {
66
+ position: absolute;
67
+ top: -12px; left: 50%;
68
+ transform: translateX(-50%);
69
+ color: ${theme.color.text};
70
+ padding: 0 ${theme.space.s};
71
+ line-height: ${theme.typography.lineHeight};
72
+ background: ${theme.color.background};
73
+ display: inline-block;
74
+ font-weight: 500;
75
+ min-height: auto;
76
+ margin: 0;
77
+ border: 1px soplid red;
78
+ }
79
+
80
+ @media (max-width: 600px) {
81
+ .rebilly-instruments-express-methods.is-compact .rebilly-instruments-express-methods-container {
82
+ flex-direction: column;
83
+ }
84
+ .rebilly-instruments-express-methods.is-compact .rebilly-instruments-express-methods-container > * {
85
+ max-width: 100%;
86
+ margin: 0 0 ${theme.space.xs};
87
+ }
88
+ .rebilly-instruments-express-methods.is-compact .rebilly-instruments-express-methods-container > *:last-child {
89
+ margin: 0;
90
+ }
91
+ }
92
+ `;
93
+
94
+ exports.expressMethods = expressMethods;
95
+
96
+ const methods = () => `
97
+ /**
98
+ * Methods
99
+ */
100
+
101
+ .rebilly-instruments-methods {}
102
+ `;
103
+
104
+ exports.methods = methods;
@@ -0,0 +1,33 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.overlay = void 0;
7
+
8
+ // -----------------------------------------------------------------------------
9
+ // This file contains all styles related to the overlay component.
10
+ // -----------------------------------------------------------------------------
11
+ const overlay = theme => `
12
+ /**
13
+ * Overlay
14
+ */
15
+ .rebilly-instruments-overlay {
16
+ position: fixed;
17
+ left: 0;
18
+ right: 0;
19
+ top: 0;
20
+ bottom: 0;
21
+ background: rgba(0,0,0,0.8);
22
+ display: flex;
23
+ justify-content: center;
24
+ align-items: center;
25
+ color: #ffffff;
26
+ font-family: ${theme.typography.fontFamily};
27
+ font-size: calc(${theme.typography.fontSize} * 1.12);
28
+ line-height: ${theme.typography.lineHeight};
29
+ z-index: 9001
30
+ }
31
+ `;
32
+
33
+ exports.overlay = overlay;
@@ -0,0 +1,59 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.helpers = void 0;
7
+
8
+ // -----------------------------------------------------------------------------
9
+ // This file contains all styles related to helpers.
10
+ // -----------------------------------------------------------------------------
11
+ const helpers = theme => `
12
+ /* Helpers
13
+ ------------------------------------------------------------ */
14
+ .rebilly-instruments-helper-visually-hidden {
15
+ border: 0;
16
+ clip: rect(0 0 0 0);
17
+ height: 1px;
18
+ margin: -1px;
19
+ overflow: hidden;
20
+ padding: 0;
21
+ position: absolute;
22
+ width: 1px;
23
+ }
24
+
25
+ .rebilly-instruments-helper-mt-xxs { margin-top: ${theme.space.xxs}!important }
26
+ .rebilly-instruments-helper-mt-xs { margin-top: ${theme.space.xs}!important }
27
+ .rebilly-instruments-helper-mt-s { margin-top: ${theme.space.s}!important }
28
+ .rebilly-instruments-helper-mt-m { margin-top: ${theme.space.m}!important }
29
+ .rebilly-instruments-helper-mt-l { margin-top: ${theme.space.l}!important }
30
+ .rebilly-instruments-helper-mt-xl { margin-top: ${theme.space.xl}!important }
31
+ .rebilly-instruments-helper-mt-xxl { margin-top: ${theme.space.xxl}!important }
32
+ .rebilly-instruments-helper-mt-0 { margin-top: 0!important }
33
+ .rebilly-instruments-helper-mr-xxs { margin-right: ${theme.space.xxs}!important }
34
+ .rebilly-instruments-helper-mr-xs { margin-right: ${theme.space.xs}!important }
35
+ .rebilly-instruments-helper-mr-s { margin-right: ${theme.space.s}!important }
36
+ .rebilly-instruments-helper-mr-m { margin-right: ${theme.space.m}!important }
37
+ .rebilly-instruments-helper-mr-l { margin-right: ${theme.space.l}!important }
38
+ .rebilly-instruments-helper-mr-xl { margin-right: ${theme.space.xl}!important }
39
+ .rebilly-instruments-helper-mr-xxl { margin-right: ${theme.space.xxl}!important }
40
+ .rebilly-instruments-helper-mr-0 { margin-right: 0!important }
41
+ .rebilly-instruments-helper-mb-xxs { margin-bottom: ${theme.space.xxs}!important }
42
+ .rebilly-instruments-helper-mb-xs { margin-bottom: ${theme.space.xs}!important }
43
+ .rebilly-instruments-helper-mb-s { margin-bottom: ${theme.space.s}!important }
44
+ .rebilly-instruments-helper-mb-m { margin-bottom: ${theme.space.m}!important }
45
+ .rebilly-instruments-helper-mb-l { margin-bottom: ${theme.space.l}!important }
46
+ .rebilly-instruments-helper-mb-xl { margin-bottom: ${theme.space.xl}!important }
47
+ .rebilly-instruments-helper-mb-xxl { margin-bottom: ${theme.space.xxl}!important }
48
+ .rebilly-instruments-helper-mb-0 { margin-bottom: 0!important }
49
+ .rebilly-instruments-helper-ml-xxs { margin-left: ${theme.space.xxs}!important }
50
+ .rebilly-instruments-helper-ml-xs { margin-left: ${theme.space.xs}!important }
51
+ .rebilly-instruments-helper-ml-s { margin-left: ${theme.space.s}!important }
52
+ .rebilly-instruments-helper-ml-m { margin-left: ${theme.space.m}!important }
53
+ .rebilly-instruments-helper-ml-l { margin-left: ${theme.space.l}!important }
54
+ .rebilly-instruments-helper-ml-xl { margin-left: ${theme.space.xl}!important }
55
+ .rebilly-instruments-helper-ml-xxl { margin-left: ${theme.space.xxl}!important }
56
+ .rebilly-instruments-helper-ml-0 { margin-left: 0!important }
57
+ `;
58
+
59
+ exports.helpers = helpers;
@@ -0,0 +1,48 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.mainStyle = void 0;
7
+
8
+ var _postcss = _interopRequireDefault(require("postcss"));
9
+
10
+ var _autoprefixer = _interopRequireDefault(require("autoprefixer"));
11
+
12
+ var _browserslist = require("./browserslist");
13
+
14
+ var _theme = require("./base/theme");
15
+
16
+ var _base = require("./base");
17
+
18
+ var _framepay = require("./vendor/framepay");
19
+
20
+ var _postmate = require("./vendor/postmate");
21
+
22
+ var _components = require("./components");
23
+
24
+ var _paymentInstruments = require("./payment-instruments");
25
+
26
+ var _views = require("./views");
27
+
28
+ var _helpers = require("./helpers");
29
+
30
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
31
+
32
+ const mainStyle = async themeOverride => {
33
+ const resolvedTheme = new _theme.Theme(themeOverride).build();
34
+ const style = `
35
+ ${(0, _base.base)(resolvedTheme)}
36
+ ${(0, _components.components)(resolvedTheme)}
37
+ ${(0, _views.views)(resolvedTheme)}
38
+ ${(0, _paymentInstruments.paymentInstruments)(resolvedTheme)}
39
+ ${(0, _framepay.framepayStyle)(resolvedTheme)}
40
+ ${(0, _postmate.postmateStyle)(resolvedTheme)}
41
+ ${(0, _helpers.helpers)(resolvedTheme)}
42
+ `;
43
+ return (0, _postcss.default)([(0, _autoprefixer.default)(_browserslist.browserslist)]).process(style, {
44
+ from: undefined
45
+ }).then(result => result.css);
46
+ };
47
+
48
+ exports.mainStyle = mainStyle;
@@ -0,0 +1,17 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.methodContent = void 0;
7
+
8
+ const methodContent = () => `
9
+ /**
10
+ * Content
11
+ */
12
+ .rebilly-instruments-method-content {
13
+ padding: 2px;
14
+ }
15
+ `;
16
+
17
+ exports.methodContent = methodContent;
@@ -0,0 +1,20 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.paymentInstruments = void 0;
7
+
8
+ var _content = require("./content");
9
+
10
+ var _paymentCard = require("./payment-card");
11
+
12
+ // Order of components matters for style cascade
13
+ const paymentInstruments = theme => `
14
+ /* Payment instruments
15
+ ------------------------------------------------------------ */
16
+ ${(0, _content.methodContent)()}
17
+ ${(0, _paymentCard.paymentCard)(theme)}
18
+ `;
19
+
20
+ exports.paymentInstruments = paymentInstruments;
@@ -0,0 +1,35 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.paymentCard = void 0;
7
+
8
+ const paymentCard = theme => `
9
+ /**
10
+ * Payment card
11
+ */
12
+ .rebilly-instruments-payment-card-brands {
13
+ display: inline-flex;
14
+ width: 100%;
15
+ justify-content: flex-end;
16
+ margin-top: ${theme.space.s}
17
+ }
18
+
19
+ .rebilly-instruments-payment-card-brands figure {
20
+ margin: 0 0 0 ${theme.space.xxs};
21
+ padding: 0;
22
+ height: 26px;
23
+ }
24
+
25
+ .rebilly-instruments-payment-card-brands figure img {
26
+ width: 42px;
27
+ border-radius: ${theme.borderRadius};
28
+ }
29
+
30
+ .rebilly-instruments-modal-container.rebilly-instruments-payment-card {
31
+ max-width: 600px;
32
+ }
33
+ `;
34
+
35
+ exports.paymentCard = paymentCard;
@@ -0,0 +1,22 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.alphaColor = alphaColor;
7
+ exports.colorValues = void 0;
8
+
9
+ var _values = _interopRequireDefault(require("values.js"));
10
+
11
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
12
+
13
+ const colorValues = color => new _values.default(color);
14
+
15
+ exports.colorValues = colorValues;
16
+
17
+ function alphaColor(color, alphaValue = 1) {
18
+ const _alphaColor = new _values.default(color);
19
+
20
+ _alphaColor.alpha = alphaValue;
21
+ return _alphaColor.rgbString();
22
+ }
@@ -0,0 +1,34 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.framepayStyle = void 0;
7
+
8
+ const framepayStyle = theme => `
9
+ .rebilly-instruments-framepay .rebilly-framepay {
10
+ box-shadow: none;
11
+ min-height: ${theme.space.form.minHeight};
12
+ border: 1px solid ${theme.getComputed.color.mutedBorder};
13
+ margin-bottom: 0;
14
+ background: ${theme.color.background};
15
+ }
16
+
17
+ .rebilly-instruments-framepay .rebilly-framepay.rebilly-framepay-focus {
18
+ border: 1px solid ${theme.color.primary};
19
+ box-shadow: 0 0 0 1px ${theme.color.primary};
20
+ }
21
+
22
+ .rebilly-instruments-framepay .rebilly-framepay.rebilly-framepay-invalid {
23
+ border: 1px solid ${theme.color.errorText};
24
+ box-shadow: none;
25
+ }
26
+
27
+ .rebilly-instruments-framepay .rebilly-framepay.rebilly-framepay-digital-wallet {
28
+ min-height: auto;
29
+ border: none;
30
+ margin: 0;
31
+ }
32
+ `;
33
+
34
+ exports.framepayStyle = framepayStyle;
@@ -0,0 +1,17 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.postmateStyle = void 0;
7
+
8
+ const postmateStyle = theme => `
9
+ .rebilly-instruments-iframe {
10
+ border: none;
11
+ width: 100%;
12
+ min-height: ${theme.space.form.minHeight};
13
+ transition: all 0.2s ease;
14
+ }
15
+ `;
16
+
17
+ exports.postmateStyle = postmateStyle;
@@ -0,0 +1,85 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.confirmation = void 0;
7
+
8
+ // -----------------------------------------------------------------------------
9
+ // This file contains all styles related to the confirmation view.
10
+ // -----------------------------------------------------------------------------
11
+ const confirmation = theme => `
12
+ /**
13
+ * Confirmation
14
+ */
15
+ .rebilly-instruments-confirmation {
16
+ padding: 2px;
17
+ }
18
+
19
+ .rebilly-instruments-confirmation-go-back-link {
20
+ display: inline-block;
21
+ margin-bottom: ${theme.space.m};
22
+ margin-left: -${theme.space.xs};
23
+ }
24
+
25
+ .rebilly-instruments-confirmation-address-title {
26
+ display: flex;
27
+ justify-content: flex-start;
28
+ }
29
+
30
+ .rebilly-instruments-confirmation-address-title .rebilly-instruments-link {
31
+ margin-left: ${theme.space.s};
32
+ }
33
+
34
+ .rebilly-instruments-confirmation-address-actions {
35
+ margin-top: ${theme.space.m};
36
+ display: flex;
37
+ }
38
+
39
+ .rebilly-instruments-confirmation-address-actions :first-child {
40
+ margin: 0 ${theme.space.xs} 0 0;
41
+ }
42
+
43
+ .rebilly-instruments-confirmation-address-actions :last-child {
44
+ margin: 0 0 0 ${theme.space.xs};
45
+ }
46
+
47
+ .rebilly-instruments-confirmation-payment-method {
48
+ display: inline-flex;
49
+ align-items: center;
50
+ justify-content: space-between;
51
+ height: 26px;
52
+ margin: 0 0 ${theme.space.l};
53
+ }
54
+
55
+ .rebilly-instruments-confirmation-payment-method figure {
56
+ margin: 0 ${theme.space.xxs} 0 0;
57
+ height: 26px;
58
+ padding: 0;
59
+ }
60
+
61
+ .rebilly-instruments-confirmation-payment-method figure img {
62
+ width: 42px;
63
+ border-radius: ${theme.borderRadius};
64
+ }
65
+
66
+ .rebilly-instruments-confirmation-payment-method-brand,
67
+ .rebilly-instruments-confirmation-payment-method-exp,
68
+ .rebilly-instruments-confirmation-payment-method-last4 {
69
+ display: inline-block;
70
+ }
71
+
72
+ .rebilly-instruments-confirmation-payment-method-brand {
73
+ margin: 0 0 0 ${theme.space.s};
74
+ }
75
+
76
+ .rebilly-instruments-confirmation-payment-method-last4 {
77
+ margin: 0 ${theme.space.s};
78
+ }
79
+
80
+ .rebilly-instruments-confirmation-payment-method-exp {
81
+ color: ${theme.getComputed.color.mutedText};
82
+ }
83
+ `;
84
+
85
+ exports.confirmation = confirmation;
@@ -0,0 +1,29 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.views = void 0;
7
+
8
+ var _summary = require("./summary");
9
+
10
+ var _methodSelector = require("./method-selector");
11
+
12
+ var _confirmation = require("./confirmation");
13
+
14
+ var _result = require("./result");
15
+
16
+ var _modal = require("./modal");
17
+
18
+ // Order of components matters for style cascade
19
+ const views = theme => `
20
+ /* Views
21
+ ------------------------------------------------------------ */
22
+ ${(0, _summary.summary)(theme)}
23
+ ${(0, _methodSelector.methodSelector)(theme)}
24
+ ${(0, _confirmation.confirmation)(theme)}
25
+ ${(0, _result.result)(theme)}
26
+ ${(0, _modal.modal)(theme)}
27
+ `;
28
+
29
+ exports.views = views;