crmbonus-component-wake 1.0.47 → 2.0.48

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 (288) hide show
  1. package/dist/cjs/app-modal.cjs.entry.js +28 -0
  2. package/dist/cjs/app-modal.cjs.entry.js.map +1 -0
  3. package/dist/cjs/countdown-timer_4.cjs.entry.js +176 -0
  4. package/dist/cjs/countdown-timer_4.cjs.entry.js.map +1 -0
  5. package/dist/cjs/crm-bonus-form.cjs.entry.js +103 -0
  6. package/dist/cjs/crm-bonus-form.cjs.entry.js.map +1 -0
  7. package/dist/cjs/crm-bonus-note.cjs.entry.js +16 -6
  8. package/dist/cjs/crm-bonus-note.cjs.entry.js.map +1 -1
  9. package/dist/cjs/crm-bonus.cjs.entry.js +41 -5
  10. package/dist/cjs/crm-bonus.cjs.entry.js.map +1 -1
  11. package/dist/cjs/crm-button.cjs.entry.js +24 -0
  12. package/dist/cjs/crm-button.cjs.entry.js.map +1 -0
  13. package/dist/cjs/crm-giftback-form.cjs.entry.js +171 -0
  14. package/dist/cjs/crm-giftback-form.cjs.entry.js.map +1 -0
  15. package/dist/cjs/crmbonus-component-wake.cjs.js +2 -2
  16. package/dist/cjs/{crmbonus.service-e375ebfe.js → crmbonus.service-7991795d.js} +10 -2
  17. package/dist/cjs/crmbonus.service-7991795d.js.map +1 -0
  18. package/dist/cjs/giftback-finish_4.cjs.entry.js +6 -6
  19. package/dist/cjs/giftback-finish_4.cjs.entry.js.map +1 -1
  20. package/dist/cjs/i18n-818275e6.js +2209 -0
  21. package/dist/cjs/i18n-818275e6.js.map +1 -0
  22. package/dist/cjs/{index-52d8a075.js → index-80419303.js} +9 -4
  23. package/dist/cjs/index-80419303.js.map +1 -0
  24. package/dist/cjs/{index-861e0cbe.js → index-96a8951f.js} +5 -1
  25. package/dist/cjs/index-96a8951f.js.map +1 -0
  26. package/dist/cjs/info.config.helper-c5d9f781.js +16 -0
  27. package/dist/cjs/info.config.helper-c5d9f781.js.map +1 -0
  28. package/dist/cjs/loader.cjs.js +2 -2
  29. package/dist/cjs/loading-spinner.cjs.entry.js +2 -2
  30. package/dist/cjs/pedido-finalizado.cjs.entry.js +3 -3
  31. package/dist/cjs/phone-cancel-input.cjs.entry.js +25 -0
  32. package/dist/cjs/phone-cancel-input.cjs.entry.js.map +1 -0
  33. package/dist/cjs/phone-input-mask.cjs.entry.js +17 -4
  34. package/dist/cjs/phone-input-mask.cjs.entry.js.map +1 -1
  35. package/dist/cjs/phone-input.cjs.entry.js +25 -0
  36. package/dist/cjs/phone-input.cjs.entry.js.map +1 -0
  37. package/dist/collection/collection-manifest.json +6 -0
  38. package/dist/collection/components/button/crm-button.css +22 -0
  39. package/dist/collection/components/button/index.js +59 -0
  40. package/dist/collection/components/button/index.js.map +1 -1
  41. package/dist/collection/components/countdown-timer/countdown-timer.js +51 -0
  42. package/dist/collection/components/countdown-timer/countdown-timer.js.map +1 -0
  43. package/dist/collection/components/crm-bonus/crm-bonus.css +0 -3
  44. package/dist/collection/components/crm-bonus/crm-bonus.js +38 -2
  45. package/dist/collection/components/crm-bonus/crm-bonus.js.map +1 -1
  46. package/dist/collection/components/crm-bonus-form/crm-bonus-form.js +2 -2
  47. package/dist/collection/components/crm-bonus-form/subcomponents/giftback-finish/giftback-finish.js +1 -1
  48. package/dist/collection/components/crm-bonus-form/subcomponents/giftback-pin/giftback-pin.css +1 -5
  49. package/dist/collection/components/crm-bonus-form/subcomponents/giftback-pin/giftback-pin.js +1 -1
  50. package/dist/collection/components/crm-bonus-form/subcomponents/giftback-progress/giftback-progress.css +1 -0
  51. package/dist/collection/components/crm-bonus-form/subcomponents/giftback-progress/giftback-progress.js +1 -1
  52. package/dist/collection/components/crm-bonus-form/subcomponents/name-input/name-input.js +1 -1
  53. package/dist/collection/components/crm-bonus-form/subcomponents/phone/phone.input.js +1 -1
  54. package/dist/collection/components/crm-bonus-form/subcomponents/phone-cancel/phone.cancel.input.js +1 -1
  55. package/dist/collection/components/giftback-form/giftback-form.css +74 -0
  56. package/dist/collection/components/giftback-form/giftback-form.js +246 -0
  57. package/dist/collection/components/giftback-form/giftback-form.js.map +1 -0
  58. package/dist/collection/components/giftback-form/subcomponents/giftback-info/giftback-info.css +154 -0
  59. package/dist/collection/components/giftback-form/subcomponents/giftback-info/giftback-info.js +156 -0
  60. package/dist/collection/components/giftback-form/subcomponents/giftback-info/giftback-info.js.map +1 -0
  61. package/dist/collection/components/giftback-form/subcomponents/giftback-message/giftback-massage.js +11 -0
  62. package/dist/collection/components/giftback-form/subcomponents/giftback-message/giftback-massage.js.map +1 -0
  63. package/dist/collection/components/giftback-form/subcomponents/phone-form/phone-form.js +80 -0
  64. package/dist/collection/components/giftback-form/subcomponents/phone-form/phone-form.js.map +1 -0
  65. package/dist/collection/components/giftback-form/subcomponents/pin-form/pin-form.css +84 -0
  66. package/dist/collection/components/giftback-form/subcomponents/pin-form/pin-form.js +174 -0
  67. package/dist/collection/components/giftback-form/subcomponents/pin-form/pin-form.js.map +1 -0
  68. package/dist/collection/components/loading-spinner/loading-spinner.js +1 -1
  69. package/dist/collection/components/modal/app-modal.js +1 -1
  70. package/dist/collection/components/note/crm-bonus-note.css +23 -7
  71. package/dist/collection/components/note/crm-bonus-note.js +33 -5
  72. package/dist/collection/components/note/crm-bonus-note.js.map +1 -1
  73. package/dist/collection/components/pedido/pedido.js +1 -1
  74. package/dist/collection/components/phone/phone-input-mask.css +18 -39
  75. package/dist/collection/components/phone/phone-input-mask.js +17 -3
  76. package/dist/collection/components/phone/phone-input-mask.js.map +1 -1
  77. package/dist/collection/contants/index.js +2 -0
  78. package/dist/collection/contants/index.js.map +1 -1
  79. package/dist/collection/helpers/info.config.helper.js +11 -0
  80. package/dist/collection/helpers/info.config.helper.js.map +1 -0
  81. package/dist/collection/i18n/i18n.js +25 -0
  82. package/dist/collection/i18n/i18n.js.map +1 -0
  83. package/dist/collection/services/crmbonus.service.js +8 -0
  84. package/dist/collection/services/crmbonus.service.js.map +1 -1
  85. package/dist/components/app-modal.js +39 -1
  86. package/dist/components/app-modal.js.map +1 -1
  87. package/dist/components/countdown-timer.d.ts +11 -0
  88. package/dist/components/countdown-timer.js +8 -0
  89. package/dist/components/countdown-timer.js.map +1 -0
  90. package/dist/components/crm-bonus-form.js +158 -1
  91. package/dist/components/crm-bonus-form.js.map +1 -1
  92. package/dist/components/crm-bonus-note.js +19 -7
  93. package/dist/components/crm-bonus-note.js.map +1 -1
  94. package/dist/components/crm-bonus.js +58 -33
  95. package/dist/components/crm-bonus.js.map +1 -1
  96. package/dist/components/crm-button.d.ts +11 -0
  97. package/dist/components/crm-button.js +8 -0
  98. package/dist/components/crm-button.js.map +1 -0
  99. package/dist/components/crm-giftback-form.d.ts +11 -0
  100. package/dist/components/crm-giftback-form.js +8 -0
  101. package/dist/components/crm-giftback-form.js.map +1 -0
  102. package/dist/components/giftback-finish.js +1 -1
  103. package/dist/components/giftback-info.d.ts +11 -0
  104. package/dist/components/giftback-info.js +8 -0
  105. package/dist/components/giftback-info.js.map +1 -0
  106. package/dist/components/giftback-pin.js +1 -1
  107. package/dist/components/giftback-progress.js +1 -1
  108. package/dist/components/index.js +1 -1
  109. package/dist/components/loading-spinner.js +1 -1
  110. package/dist/components/name-input.js +1 -1
  111. package/dist/components/p-0a57e57f.js +91 -0
  112. package/dist/components/p-0a57e57f.js.map +1 -0
  113. package/dist/components/p-1d5eeac0.js +2207 -0
  114. package/dist/components/p-1d5eeac0.js.map +1 -0
  115. package/dist/components/{p-faf7103e.js → p-2f266d73.js} +6 -2
  116. package/dist/components/p-2f266d73.js.map +1 -0
  117. package/dist/{esm/crmbonus.service-4ee773c8.js → components/p-384fabf7.js} +10 -2
  118. package/dist/components/p-384fabf7.js.map +1 -0
  119. package/dist/components/p-39d680b6.js +49 -0
  120. package/dist/components/p-39d680b6.js.map +1 -0
  121. package/dist/components/p-46578efa.js +44 -0
  122. package/dist/components/p-46578efa.js.map +1 -0
  123. package/dist/components/{p-0e99f907.js → p-4f18f4c0.js} +5 -5
  124. package/dist/components/p-4f18f4c0.js.map +1 -0
  125. package/dist/components/{p-ddc0ac71.js → p-5c3fe5a8.js} +3 -3
  126. package/dist/components/{p-ddc0ac71.js.map → p-5c3fe5a8.js.map} +1 -1
  127. package/dist/components/p-5f0003a4.js +62 -0
  128. package/dist/components/p-5f0003a4.js.map +1 -0
  129. package/dist/components/p-6703fdff.js +106 -0
  130. package/dist/components/p-6703fdff.js.map +1 -0
  131. package/dist/components/p-6a95cc63.js +238 -0
  132. package/dist/components/p-6a95cc63.js.map +1 -0
  133. package/dist/components/p-75ba7b9a.js +14 -0
  134. package/dist/components/p-75ba7b9a.js.map +1 -0
  135. package/dist/components/{p-19b83423.js → p-a30bd6b1.js} +4 -4
  136. package/dist/components/{p-19b83423.js.map → p-a30bd6b1.js.map} +1 -1
  137. package/dist/{esm/index-ea02697e.js → components/p-a561251a.js} +4 -2
  138. package/dist/components/p-a561251a.js.map +1 -0
  139. package/dist/components/p-be365312.js +76 -0
  140. package/dist/components/p-be365312.js.map +1 -0
  141. package/dist/components/{p-e2727638.js → p-f168d5f6.js} +4 -4
  142. package/dist/components/p-f168d5f6.js.map +1 -0
  143. package/dist/components/{p-530006e6.js → p-f5fcff75.js} +3 -3
  144. package/dist/components/{p-530006e6.js.map → p-f5fcff75.js.map} +1 -1
  145. package/dist/components/pedido-finalizado.js +3 -3
  146. package/dist/components/phone-cancel-input.js +48 -1
  147. package/dist/components/phone-cancel-input.js.map +1 -1
  148. package/dist/components/phone-form.d.ts +11 -0
  149. package/dist/components/phone-form.js +8 -0
  150. package/dist/components/phone-form.js.map +1 -0
  151. package/dist/components/phone-input-mask.js +1 -1
  152. package/dist/components/phone-input.js +48 -1
  153. package/dist/components/phone-input.js.map +1 -1
  154. package/dist/components/pin-form.d.ts +11 -0
  155. package/dist/components/pin-form.js +8 -0
  156. package/dist/components/pin-form.js.map +1 -0
  157. package/dist/crmbonus-component-wake/crmbonus-component-wake.css +1 -0
  158. package/dist/crmbonus-component-wake/crmbonus-component-wake.esm.js +1 -1
  159. package/dist/crmbonus-component-wake/crmbonus-component-wake.esm.js.map +1 -1
  160. package/dist/crmbonus-component-wake/p-1d5eeac0.js +2 -0
  161. package/dist/crmbonus-component-wake/p-1d5eeac0.js.map +1 -0
  162. package/dist/crmbonus-component-wake/{p-878c694e.js → p-384fabf7.js} +2 -2
  163. package/dist/crmbonus-component-wake/p-384fabf7.js.map +1 -0
  164. package/dist/crmbonus-component-wake/{p-a01c57ab.entry.js → p-3beb5158.entry.js} +2 -2
  165. package/dist/crmbonus-component-wake/p-5a8fa5b9.entry.js +2 -0
  166. package/dist/crmbonus-component-wake/p-5a8fa5b9.entry.js.map +1 -0
  167. package/dist/crmbonus-component-wake/p-5ede3b10.entry.js +2 -0
  168. package/dist/crmbonus-component-wake/p-5ede3b10.entry.js.map +1 -0
  169. package/dist/crmbonus-component-wake/p-66f41fd0.entry.js +2 -0
  170. package/dist/crmbonus-component-wake/p-66f41fd0.entry.js.map +1 -0
  171. package/dist/crmbonus-component-wake/p-6e6bf96e.js +3 -0
  172. package/dist/crmbonus-component-wake/p-6e6bf96e.js.map +1 -0
  173. package/dist/crmbonus-component-wake/p-75ba7b9a.js +2 -0
  174. package/dist/crmbonus-component-wake/p-75ba7b9a.js.map +1 -0
  175. package/dist/crmbonus-component-wake/p-830b5bdc.entry.js +2 -0
  176. package/dist/crmbonus-component-wake/p-830b5bdc.entry.js.map +1 -0
  177. package/dist/crmbonus-component-wake/p-8944b009.entry.js +2 -0
  178. package/dist/crmbonus-component-wake/p-8944b009.entry.js.map +1 -0
  179. package/dist/crmbonus-component-wake/p-8b9a1aec.entry.js +2 -0
  180. package/dist/crmbonus-component-wake/p-8b9a1aec.entry.js.map +1 -0
  181. package/dist/crmbonus-component-wake/{p-001e3e2b.entry.js → p-9514339e.entry.js} +2 -2
  182. package/dist/crmbonus-component-wake/p-a561251a.js +2 -0
  183. package/dist/crmbonus-component-wake/p-a561251a.js.map +1 -0
  184. package/dist/crmbonus-component-wake/p-adb37e26.entry.js +2 -0
  185. package/dist/crmbonus-component-wake/p-adb37e26.entry.js.map +1 -0
  186. package/dist/crmbonus-component-wake/p-c72a11ba.entry.js +2 -0
  187. package/dist/crmbonus-component-wake/p-c72a11ba.entry.js.map +1 -0
  188. package/dist/crmbonus-component-wake/p-cc452df3.entry.js +2 -0
  189. package/dist/crmbonus-component-wake/p-cc452df3.entry.js.map +1 -0
  190. package/dist/crmbonus-component-wake/p-d0349daf.entry.js +2 -0
  191. package/dist/crmbonus-component-wake/p-d0349daf.entry.js.map +1 -0
  192. package/dist/crmbonus-component-wake/p-e9cc180e.entry.js +2 -0
  193. package/dist/crmbonus-component-wake/p-e9cc180e.entry.js.map +1 -0
  194. package/dist/env.js +1 -1
  195. package/dist/env.js.map +1 -1
  196. package/dist/esm/app-modal.entry.js +24 -0
  197. package/dist/esm/app-modal.entry.js.map +1 -0
  198. package/dist/esm/countdown-timer_4.entry.js +169 -0
  199. package/dist/esm/countdown-timer_4.entry.js.map +1 -0
  200. package/dist/esm/crm-bonus-form.entry.js +99 -0
  201. package/dist/esm/crm-bonus-form.entry.js.map +1 -0
  202. package/dist/esm/crm-bonus-note.entry.js +16 -6
  203. package/dist/esm/crm-bonus-note.entry.js.map +1 -1
  204. package/dist/esm/crm-bonus.entry.js +41 -5
  205. package/dist/esm/crm-bonus.entry.js.map +1 -1
  206. package/dist/esm/crm-button.entry.js +20 -0
  207. package/dist/esm/crm-button.entry.js.map +1 -0
  208. package/dist/esm/crm-giftback-form.entry.js +167 -0
  209. package/dist/esm/crm-giftback-form.entry.js.map +1 -0
  210. package/dist/esm/crmbonus-component-wake.js +3 -3
  211. package/dist/{components/p-878c694e.js → esm/crmbonus.service-a846150c.js} +10 -2
  212. package/dist/esm/crmbonus.service-a846150c.js.map +1 -0
  213. package/dist/esm/giftback-finish_4.entry.js +6 -6
  214. package/dist/esm/giftback-finish_4.entry.js.map +1 -1
  215. package/dist/esm/i18n-853fedb3.js +2207 -0
  216. package/dist/esm/i18n-853fedb3.js.map +1 -0
  217. package/dist/esm/index-3c6d4feb.js +14 -0
  218. package/dist/esm/index-3c6d4feb.js.map +1 -0
  219. package/dist/esm/{index-9f7bde48.js → index-a4c14fca.js} +9 -4
  220. package/dist/esm/index-a4c14fca.js.map +1 -0
  221. package/dist/esm/info.config.helper-42d9ddf9.js +14 -0
  222. package/dist/esm/info.config.helper-42d9ddf9.js.map +1 -0
  223. package/dist/esm/loader.js +3 -3
  224. package/dist/esm/loading-spinner.entry.js +2 -2
  225. package/dist/esm/pedido-finalizado.entry.js +3 -3
  226. package/dist/esm/phone-cancel-input.entry.js +21 -0
  227. package/dist/esm/phone-cancel-input.entry.js.map +1 -0
  228. package/dist/esm/phone-input-mask.entry.js +17 -4
  229. package/dist/esm/phone-input-mask.entry.js.map +1 -1
  230. package/dist/esm/phone-input.entry.js +21 -0
  231. package/dist/esm/phone-input.entry.js.map +1 -0
  232. package/dist/types/components/button/index.d.ts +5 -0
  233. package/dist/types/components/countdown-timer/countdown-timer.d.ts +8 -0
  234. package/dist/types/components/crm-bonus/crm-bonus.d.ts +1 -0
  235. package/dist/types/components/giftback-form/giftback-form.d.ts +32 -0
  236. package/dist/types/components/giftback-form/subcomponents/giftback-info/giftback-info.d.ts +15 -0
  237. package/dist/types/components/giftback-form/subcomponents/giftback-message/giftback-massage.d.ts +3 -0
  238. package/dist/types/components/giftback-form/subcomponents/phone-form/phone-form.d.ts +8 -0
  239. package/dist/types/components/giftback-form/subcomponents/pin-form/pin-form.d.ts +19 -0
  240. package/dist/types/components/note/crm-bonus-note.d.ts +4 -0
  241. package/dist/types/components/phone/phone-input-mask.d.ts +2 -0
  242. package/dist/types/components.d.ts +118 -0
  243. package/dist/types/contants/index.d.ts +3 -1
  244. package/dist/types/helpers/info.config.helper.d.ts +6 -0
  245. package/dist/types/i18n/i18n.d.ts +2 -0
  246. package/dist/types/services/crmbonus.service.d.ts +1 -0
  247. package/package.json +3 -2
  248. package/dist/cjs/app-modal_4.cjs.entry.js +0 -157
  249. package/dist/cjs/app-modal_4.cjs.entry.js.map +0 -1
  250. package/dist/cjs/crmbonus.service-e375ebfe.js.map +0 -1
  251. package/dist/cjs/index-52d8a075.js.map +0 -1
  252. package/dist/cjs/index-861e0cbe.js.map +0 -1
  253. package/dist/components/p-03c2447c.js +0 -170
  254. package/dist/components/p-03c2447c.js.map +0 -1
  255. package/dist/components/p-0e99f907.js.map +0 -1
  256. package/dist/components/p-1dbb0f43.js +0 -43
  257. package/dist/components/p-1dbb0f43.js.map +0 -1
  258. package/dist/components/p-3c29c6ad.js +0 -62
  259. package/dist/components/p-3c29c6ad.js.map +0 -1
  260. package/dist/components/p-41d42a66.js +0 -52
  261. package/dist/components/p-41d42a66.js.map +0 -1
  262. package/dist/components/p-6c553ee7.js +0 -52
  263. package/dist/components/p-6c553ee7.js.map +0 -1
  264. package/dist/components/p-878c694e.js.map +0 -1
  265. package/dist/components/p-e2727638.js.map +0 -1
  266. package/dist/components/p-faf7103e.js.map +0 -1
  267. package/dist/crmbonus-component-wake/p-002f2417.entry.js +0 -2
  268. package/dist/crmbonus-component-wake/p-002f2417.entry.js.map +0 -1
  269. package/dist/crmbonus-component-wake/p-2636f2f0.entry.js +0 -2
  270. package/dist/crmbonus-component-wake/p-2636f2f0.entry.js.map +0 -1
  271. package/dist/crmbonus-component-wake/p-3582baf8.entry.js +0 -2
  272. package/dist/crmbonus-component-wake/p-3582baf8.entry.js.map +0 -1
  273. package/dist/crmbonus-component-wake/p-5febaa3c.entry.js +0 -2
  274. package/dist/crmbonus-component-wake/p-5febaa3c.entry.js.map +0 -1
  275. package/dist/crmbonus-component-wake/p-61df4eb6.entry.js +0 -2
  276. package/dist/crmbonus-component-wake/p-61df4eb6.entry.js.map +0 -1
  277. package/dist/crmbonus-component-wake/p-72510682.js +0 -3
  278. package/dist/crmbonus-component-wake/p-72510682.js.map +0 -1
  279. package/dist/crmbonus-component-wake/p-878c694e.js.map +0 -1
  280. package/dist/crmbonus-component-wake/p-9b967605.js +0 -2
  281. package/dist/crmbonus-component-wake/p-9b967605.js.map +0 -1
  282. package/dist/esm/app-modal_4.entry.js +0 -150
  283. package/dist/esm/app-modal_4.entry.js.map +0 -1
  284. package/dist/esm/crmbonus.service-4ee773c8.js.map +0 -1
  285. package/dist/esm/index-9f7bde48.js.map +0 -1
  286. package/dist/esm/index-ea02697e.js.map +0 -1
  287. /package/dist/crmbonus-component-wake/{p-a01c57ab.entry.js.map → p-3beb5158.entry.js.map} +0 -0
  288. /package/dist/crmbonus-component-wake/{p-001e3e2b.entry.js.map → p-9514339e.entry.js.map} +0 -0
@@ -0,0 +1,74 @@
1
+ * {
2
+ margin: 0;
3
+ padding: 0;
4
+ box-sizing: border-box;
5
+ }
6
+
7
+ :host {
8
+ --crmfont-sizebodymd: 14px;
9
+ --crmline-heightbodymd: 20px;
10
+ --crmletter-spacingtitle-md: 0px
11
+ }
12
+
13
+ .container-message {
14
+ font-family: Roboto;
15
+ font-size: var(--crmfont-sizebodymd);
16
+ font-weight: 400;
17
+ line-height: var(--crmline-heightbodymd);
18
+ letter-spacing: var(--crmletter-spacingtitle-md);
19
+ text-align: left;
20
+ text-underline-position: from-font;
21
+ text-decoration-skip-ink: none;
22
+ }
23
+
24
+ .crm-container-form {
25
+ display: flex;
26
+ flex-direction: column;
27
+ justify-content: space-around;
28
+ height: auto;
29
+ padding: 20px 24px 20px 24px;
30
+ border-block: 1px solid #CCCC;
31
+ writing-mode: horizontal-tb;
32
+ gap: 16px;
33
+ border-top: 1px solid #ccc !important;
34
+ border-bottom: 1px solid #ccc !important;
35
+ }
36
+
37
+ /* .fbits-responsive-carrinho-desconto {
38
+ overflow: hidden;
39
+ border: 1px solid #ccc;
40
+ border-top: 0;
41
+ border-bottom: 0;
42
+ } */
43
+
44
+ .crm-phone-form {
45
+ display: flex;
46
+ flex-direction: column;
47
+ height: 100%;
48
+ /* justify-content: space-around; */
49
+ gap: 16px;
50
+ }
51
+
52
+ .crm-subtitle {
53
+ font-size: 14px;
54
+ color: var(--crm-btn);
55
+ }
56
+
57
+ .crm-title {
58
+ font-weight: 700;
59
+ line-height: 20px;
60
+ color: #262626;
61
+ font-size: 16px;
62
+ }
63
+
64
+ .crm-message-info {
65
+ color: #619013;
66
+ font-weight: 500;
67
+ font-size: 12px;
68
+ }
69
+
70
+ .crm-message-error {
71
+ color: #E11D48;
72
+ font-weight: 500;
73
+ font-size: 12px;
74
+ }
@@ -0,0 +1,246 @@
1
+ import { h } from "@stencil/core";
2
+ import { CrmBonusService } from "../../services/crmbonus.service";
3
+ import { StepFormEnum } from "../../contants";
4
+ import { getInfoCustomization } from "../../helpers/info.config.helper";
5
+ import i18next from "../../i18n/i18n";
6
+ export class CrmBonus {
7
+ constructor() {
8
+ // private phoneInputMask: HTMLPhoneFormElement;
9
+ this.crmBonusService = CrmBonusService.getInstance();
10
+ this.storeName = undefined;
11
+ this.cartId = undefined;
12
+ this.products = undefined;
13
+ this.value = undefined;
14
+ this.loading = false;
15
+ this.message = undefined;
16
+ this.phone = undefined;
17
+ this.pinInfo = undefined;
18
+ this.step = StepFormEnum.STEP_PHONE;
19
+ this.bonus = undefined;
20
+ this.sucess = "";
21
+ this.error = "";
22
+ this.config = undefined;
23
+ }
24
+ async handleSendPin(phone) {
25
+ this.message = "";
26
+ if (!phone) {
27
+ this.message = "Informe seu telefone";
28
+ return;
29
+ }
30
+ this.phone = phone;
31
+ this.sendPin();
32
+ }
33
+ componentWillLoad() {
34
+ this.sucess = "";
35
+ this.error = "";
36
+ this.config = getInfoCustomization(this.storeName);
37
+ }
38
+ convertStringToNumber() {
39
+ const _phone = this.phone.replace(/\D/g, '');
40
+ return Number(_phone);
41
+ }
42
+ async sendPin() {
43
+ var _a, _b;
44
+ this.loading = true;
45
+ this.message = "";
46
+ this.sucess = "";
47
+ this.error = "";
48
+ try {
49
+ const _phone = this.convertStringToNumber();
50
+ this.pinInfo = await this.crmBonusService.sendPin(_phone, "", this.storeName);
51
+ this.step = StepFormEnum.STEP_PIN;
52
+ }
53
+ catch (error) {
54
+ this.message = (_b = (_a = error === null || error === void 0 ? void 0 : error.response) === null || _a === void 0 ? void 0 : _a.data) === null || _b === void 0 ? void 0 : _b.message;
55
+ }
56
+ finally {
57
+ this.loading = false;
58
+ }
59
+ }
60
+ changePhone() {
61
+ this.sucess = "";
62
+ this.error = "";
63
+ this.step = StepFormEnum.STEP_PHONE;
64
+ }
65
+ async validateBonus(pin) {
66
+ var _a, _b;
67
+ if (this.sucess) {
68
+ this.step = StepFormEnum.STEP_RESERVE;
69
+ return;
70
+ }
71
+ this.loading = true;
72
+ this.sucess = "";
73
+ this.error = "";
74
+ const payload = {
75
+ pin: pin,
76
+ cellphone: this.phone.toString(),
77
+ storeId: this.pinInfo.storeId.toString(),
78
+ userId: this.pinInfo.userId.toString(),
79
+ checkoutId: this.cartId,
80
+ checkoutProducts: this.products,
81
+ name: null,
82
+ storeName: this.storeName
83
+ };
84
+ try {
85
+ this.bonus = await this.crmBonusService.validatePinBonus(payload);
86
+ this.sucess = "Código validado com sucesso!";
87
+ }
88
+ catch (error) {
89
+ const _error = (_b = (_a = error === null || error === void 0 ? void 0 : error.response) === null || _a === void 0 ? void 0 : _a.data) === null || _b === void 0 ? void 0 : _b.message;
90
+ if (_error.includes("Pin")) {
91
+ this.error = "Código inválido!";
92
+ }
93
+ else {
94
+ this.error = _error;
95
+ }
96
+ this.step = StepFormEnum.STEP_NO_BONUS;
97
+ }
98
+ finally {
99
+ this.loading = false;
100
+ }
101
+ }
102
+ handleCancel() {
103
+ // this.step = StepFormEnum.STEP_PHONE;
104
+ this.cancel();
105
+ }
106
+ async cancel() {
107
+ this.message = "";
108
+ this.loading = true;
109
+ try {
110
+ await this.crmBonusService.cancel(this.cartId);
111
+ localStorage.removeItem(this.cartId);
112
+ }
113
+ catch (error) {
114
+ this.message = "Não consegui cancelar o bônus, tente novamente!";
115
+ }
116
+ finally {
117
+ this.loading = false;
118
+ }
119
+ }
120
+ async reserveApply(amount) {
121
+ this.loading = true;
122
+ this.message = "";
123
+ try {
124
+ await this.reserve(amount);
125
+ console.log('[reserva]');
126
+ this.save(amount);
127
+ }
128
+ catch (error) {
129
+ this.message = "ocorreu um error ao solicitar a aplicação do bonus! tente novamente";
130
+ this.step = StepFormEnum.STEP_NO_BONUS;
131
+ }
132
+ finally {
133
+ this.loading = false;
134
+ }
135
+ }
136
+ save(amount) {
137
+ localStorage.setItem(this.cartId, amount.toString());
138
+ }
139
+ async reserve(amount) {
140
+ await this.crmBonusService.reserve({
141
+ redeemedBonus: amount,
142
+ cartId: this.cartId,
143
+ ticket: this.cartId,
144
+ grossValue: Number(this.bonus.totalValue),
145
+ storeName: this.storeName,
146
+ storeId: this.bonus.storeId.toString(),
147
+ userId: this.bonus.userId
148
+ });
149
+ }
150
+ render() {
151
+ return (h("div", { key: '06d78425ff758b165bb5bc70662182e6f86ad12d', class: "crm-container-form fbits-responsive-carrinho-desconto" }, h("label", { key: '920084d9a172734b5919b31871526a2809bb87be', class: "crm-title" }, this.config.giftbackTitle), this.step === StepFormEnum.STEP_PHONE &&
152
+ h("phone-form", { key: '3f78734540d1ee27f41cf7dd2eaf1702ac670f49', loading: this.loading, handlerSubmit: (phone) => this.handleSendPin(phone) }), this.step === StepFormEnum.STEP_PIN &&
153
+ h("pin-form", { key: '5b8957446dace613bcc8d01adda67d5ed4d0b34e', phone: this.phone, cancel: () => this.changePhone(), resend: () => this.sendPin(), validate: (data) => this.validateBonus(data), loading: this.loading }, this.sucess && h("p", { key: '8210548d8bcb0aba9255a5525e3c0041d11d7394', class: "crm-message-info" }, this.sucess), this.error && h("p", { key: 'ad181c7c5d11ca2e120505121939e42363c44c64', class: "crm-message-error" }, this.error)), this.step === StepFormEnum.STEP_RESERVE &&
154
+ h("giftback-info", { key: '8f9a22db846c8d8fa2d257e7bc1712be1c67b3dc', loading: this.loading, cancel: () => this.handleCancel(), bonus: this.bonus, reserve: (amountRedeemed) => this.reserveApply(amountRedeemed) }), this.step === StepFormEnum.STEP_NO_BONUS &&
155
+ (h("div", { key: '3e327792f32a22f2064f6201ff14f93fc5124964', class: "container-message" }, i18next.t("noGiftback")))));
156
+ }
157
+ static get is() { return "crm-giftback-form"; }
158
+ static get originalStyleUrls() {
159
+ return {
160
+ "$": ["giftback-form.css"]
161
+ };
162
+ }
163
+ static get styleUrls() {
164
+ return {
165
+ "$": ["giftback-form.css"]
166
+ };
167
+ }
168
+ static get properties() {
169
+ return {
170
+ "storeName": {
171
+ "type": "any",
172
+ "mutable": false,
173
+ "complexType": {
174
+ "original": "any",
175
+ "resolved": "any",
176
+ "references": {}
177
+ },
178
+ "required": false,
179
+ "optional": false,
180
+ "docs": {
181
+ "tags": [],
182
+ "text": ""
183
+ },
184
+ "attribute": "storename",
185
+ "reflect": false
186
+ },
187
+ "cartId": {
188
+ "type": "any",
189
+ "mutable": false,
190
+ "complexType": {
191
+ "original": "any",
192
+ "resolved": "any",
193
+ "references": {}
194
+ },
195
+ "required": false,
196
+ "optional": false,
197
+ "docs": {
198
+ "tags": [],
199
+ "text": ""
200
+ },
201
+ "attribute": "cart-id",
202
+ "reflect": false
203
+ },
204
+ "products": {
205
+ "type": "unknown",
206
+ "mutable": false,
207
+ "complexType": {
208
+ "original": "Array<IProduct>",
209
+ "resolved": "IProduct[]",
210
+ "references": {
211
+ "Array": {
212
+ "location": "global",
213
+ "id": "global::Array"
214
+ },
215
+ "IProduct": {
216
+ "location": "import",
217
+ "path": "../../dto/validate.pin.bonus",
218
+ "id": "src/dto/validate.pin.bonus.ts::IProduct"
219
+ }
220
+ }
221
+ },
222
+ "required": false,
223
+ "optional": false,
224
+ "docs": {
225
+ "tags": [],
226
+ "text": ""
227
+ }
228
+ }
229
+ };
230
+ }
231
+ static get states() {
232
+ return {
233
+ "value": {},
234
+ "loading": {},
235
+ "message": {},
236
+ "phone": {},
237
+ "pinInfo": {},
238
+ "step": {},
239
+ "bonus": {},
240
+ "sucess": {},
241
+ "error": {},
242
+ "config": {}
243
+ };
244
+ }
245
+ }
246
+ //# sourceMappingURL=giftback-form.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"giftback-form.js","sourceRoot":"","sources":["../../../../src/components/giftback-form/giftback-form.tsx"],"names":[],"mappings":"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","sourcesContent":["import { Component, Prop, State, h } from \"@stencil/core\";\nimport { CrmBonusService } from \"../../services/crmbonus.service\";\nimport { StepFormEnum } from \"../../contants\";\nimport { IPinSent } from '../../dto/pin.sent'\nimport { IBonus, IProccesPinBonusDto, IProduct } from \"../../dto/validate.pin.bonus\";\nimport { IInfoStore, getInfoCustomization } from \"../../helpers/info.config.helper\";\n\nimport i18next from \"../../i18n/i18n\"\n\n@Component({\n tag: 'crm-giftback-form',\n styleUrl: 'giftback-form.css'\n})\nexport class CrmBonus {\n // private phoneInputMask: HTMLPhoneFormElement;\n\n private crmBonusService: CrmBonusService = CrmBonusService.getInstance();\n\n @Prop({ attribute: 'storename' }) storeName;\n @Prop() cartId;\n @Prop() products: Array<IProduct>;\n\n @State() value: string;\n @State() loading: boolean = false;\n @State() message: string;\n @State() phone: string;\n @State() pinInfo: IPinSent;\n @State() step: StepFormEnum = StepFormEnum.STEP_PHONE;\n @State() bonus: IBonus;\n\n @State() sucess: string = \"\";\n @State() error: string = \"\";\n @State() config: IInfoStore;\n\n async handleSendPin(phone: string) {\n\n this.message = \"\"\n if (!phone) {\n this.message = \"Informe seu telefone\";\n return;\n }\n\n this.phone = phone;\n\n this.sendPin()\n }\n\n componentWillLoad() {\n this.sucess = \"\";\n this.error = \"\"\n this.config = getInfoCustomization(this.storeName);\n }\n\n private convertStringToNumber(): number {\n const _phone = this.phone.replace(/\\D/g, '');\n return Number(_phone);\n }\n\n public async sendPin() {\n this.loading = true;\n this.message = \"\";\n this.sucess = \"\";\n this.error = \"\"\n\n try {\n\n const _phone = this.convertStringToNumber()\n\n this.pinInfo = await this.crmBonusService.sendPin(_phone, \"\", this.storeName);\n\n this.step = StepFormEnum.STEP_PIN;\n\n } catch (error) {\n this.message = error?.response?.data?.message\n } finally {\n this.loading = false\n }\n }\n\n changePhone() {\n this.sucess = \"\";\n this.error = \"\"\n this.step = StepFormEnum.STEP_PHONE;\n }\n\n public async validateBonus(pin: string) {\n\n if (this.sucess) {\n this.step = StepFormEnum.STEP_RESERVE;\n return\n }\n\n this.loading = true;\n this.sucess = \"\";\n this.error = \"\";\n const payload: IProccesPinBonusDto = {\n pin: pin,\n cellphone: this.phone.toString(),\n storeId: this.pinInfo.storeId.toString(),\n userId: this.pinInfo.userId.toString(),\n checkoutId: this.cartId,\n checkoutProducts: this.products,\n name: null,\n storeName: this.storeName\n }\n\n try {\n this.bonus = await this.crmBonusService.validatePinBonus(payload);\n\n this.sucess = \"Código validado com sucesso!\";\n\n } catch (error) {\n const _error: string = error?.response?.data?.message;\n\n if (_error.includes(\"Pin\")) {\n this.error = \"Código inválido!\"\n } else {\n this.error = _error;\n }\n\n this.step = StepFormEnum.STEP_NO_BONUS;\n\n } finally {\n this.loading = false;\n }\n }\n\n public handleCancel() {\n // this.step = StepFormEnum.STEP_PHONE;\n this.cancel()\n }\n\n async cancel() {\n this.message = \"\";\n this.loading = true;\n try {\n await this.crmBonusService.cancel(this.cartId);\n localStorage.removeItem(this.cartId);\n } catch (error) {\n this.message = \"Não consegui cancelar o bônus, tente novamente!\"\n } finally {\n this.loading = false;\n }\n }\n\n public async reserveApply(amount: number) {\n this.loading = true;\n this.message = \"\";\n try {\n await this.reserve(amount);\n\n console.log('[reserva]')\n \n this.save(amount);\n } catch (error) {\n this.message = \"ocorreu um error ao solicitar a aplicação do bonus! tente novamente\"\n\n this.step = StepFormEnum.STEP_NO_BONUS;\n } finally {\n this.loading = false;\n }\n }\n\n save(amount: number) {\n localStorage.setItem(this.cartId, amount.toString());\n }\n\n public async reserve(amount: number) {\n\n await this.crmBonusService.reserve({\n redeemedBonus: amount,\n cartId: this.cartId,\n ticket: this.cartId,\n grossValue: Number(this.bonus.totalValue),\n storeName: this.storeName,\n storeId: this.bonus.storeId.toString(),\n userId: this.bonus.userId\n });\n }\n\n render() {\n return (\n <div class=\"crm-container-form fbits-responsive-carrinho-desconto\" >\n <label class=\"crm-title\">{this.config.giftbackTitle}</label>\n\n {this.step === StepFormEnum.STEP_PHONE &&\n <phone-form\n loading={this.loading}\n handlerSubmit={(phone) => this.handleSendPin(phone)}\n />}\n {\n this.step === StepFormEnum.STEP_PIN &&\n <pin-form\n phone={this.phone}\n cancel={() => this.changePhone()}\n resend={() => this.sendPin()}\n validate={(data) => this.validateBonus(data)}\n loading={this.loading}\n >\n {this.sucess && <p class=\"crm-message-info\">{this.sucess}</p>}\n {this.error && <p class=\"crm-message-error\">{this.error}</p>}\n\n </pin-form>\n }\n\n {\n this.step === StepFormEnum.STEP_RESERVE &&\n <giftback-info\n loading={this.loading}\n cancel={() => this.handleCancel()}\n bonus={this.bonus}\n reserve={(amountRedeemed: number) => this.reserveApply(amountRedeemed)}\n />\n }\n\n\n {\n this.step === StepFormEnum.STEP_NO_BONUS &&\n (\n <div class=\"container-message\">\n { i18next.t(\"noGiftback\") }\n </div>\n )\n\n }\n </div>\n )\n }\n}"]}
@@ -0,0 +1,154 @@
1
+ :host {
2
+ --text-color: #6D6D5F
3
+ }
4
+
5
+ .giftback-container {
6
+ display: flex;
7
+ flex-direction: column;
8
+ gap: 14px;
9
+ }
10
+
11
+ h3 {
12
+ font-size: 1.2rem;
13
+ margin-bottom: 8px;
14
+ color: #333;
15
+ }
16
+
17
+ .container-description p {
18
+ font-size: 14px;
19
+ font-weight: 400;
20
+ }
21
+
22
+
23
+ p {
24
+ font-size: 12px;
25
+ color: #000;
26
+ }
27
+
28
+ .value-display h2 {
29
+ color: #6D6D5F;
30
+ /* Verde para o valor atual */
31
+ font-size: 1.6rem;
32
+ margin: 16px 0;
33
+ }
34
+
35
+ input[type='range'] {
36
+ width: 100%;
37
+ margin: 12px 0;
38
+ -webkit-appearance: none;
39
+ background: #ddd;
40
+ height: 4px;
41
+ border-radius: 4px;
42
+ outline: none;
43
+ padding: 3px;
44
+ }
45
+
46
+ input[type='range']::-webkit-slider-thumb {
47
+ -webkit-appearance: none;
48
+ appearance: none;
49
+ width: 16px;
50
+ height: 16px;
51
+ background: var(--text-color);
52
+ /* Azul para o slider */
53
+ border-radius: 50%;
54
+ cursor: pointer;
55
+ }
56
+
57
+ .options {
58
+ margin: 0px 0;
59
+ display: flex;
60
+ gap: 10px;
61
+ flex-direction: column;
62
+ }
63
+
64
+ .options label {
65
+ display: block;
66
+ margin: 0px 0;
67
+ font-size: 0.9rem;
68
+ color: #333;
69
+ }
70
+
71
+ .options input[type='radio'] {
72
+ margin-right: 8px;
73
+ height: 16px;
74
+ width: 16px;
75
+ }
76
+
77
+ .options input[type='radio'] {
78
+ appearance: none;
79
+ -webkit-appearance: none;
80
+ margin-right: 8px;
81
+ width: 16px;
82
+ height: 16px;
83
+ border: 2px solid #ddd;
84
+ border-radius: 50%;
85
+ background-color: #fff;
86
+ cursor: pointer;
87
+ transition: all 0.3s;
88
+ padding: 0px;
89
+ }
90
+
91
+ .options input[type='radio']:checked {
92
+ border-color: #000;
93
+ background-color: #FAFAFA;
94
+ border: 4px solid #000;
95
+ }
96
+
97
+ .info-box {
98
+ background-color: #f9f9f9;
99
+ border: 1px solid #e0e0e0;
100
+ border-radius: 4px;
101
+ padding: 8px;
102
+ font-size: 14px;
103
+ color: #262626;
104
+ line-height: 20px;
105
+ }
106
+
107
+ .info-icon {
108
+ font-size: 0.9rem;
109
+ cursor: pointer;
110
+ color: #888;
111
+ }
112
+
113
+ h3 {
114
+ font-size: 1.2rem;
115
+ margin-bottom: 8px;
116
+ color: #333;
117
+ }
118
+
119
+ .slider-wrapper {
120
+ position: relative;
121
+ margin: 21px 0px 0px 0px;
122
+ }
123
+
124
+ .slider {
125
+ width: 100%;
126
+ -webkit-appearance: none;
127
+ background: #ddd;
128
+ height: 4px;
129
+ border-radius: 2px;
130
+ outline: none;
131
+ }
132
+
133
+ .slider::-webkit-slider-thumb {
134
+ -webkit-appearance: none;
135
+ appearance: none;
136
+ width: 16px;
137
+ height: 16px;
138
+ background: var(--text-color);
139
+ /* Azul para o slider */
140
+ border-radius: 50%;
141
+ cursor: pointer;
142
+ }
143
+
144
+ .slider-value {
145
+ position: absolute;
146
+ top: -30px;
147
+ /* Posição acima do slider */
148
+ font-size: 16px;
149
+ font-weight: 700;
150
+ color: var(--text-color);
151
+ /* Verde para o texto */
152
+ transform: translateX(-50%);
153
+ white-space: nowrap;
154
+ }
@@ -0,0 +1,156 @@
1
+ import { h } from "@stencil/core";
2
+ import i18next from "../../../../i18n/i18n";
3
+ export class GiftbackInfo {
4
+ constructor() {
5
+ this.usedValue = 0;
6
+ this.selectedOption = 'none';
7
+ this.loading = false;
8
+ this.bonus = {
9
+ totalBonus: 52,
10
+ cartId: "",
11
+ minimumPurchase: 6000,
12
+ bonusBalance: 25,
13
+ calculatedValue: 25,
14
+ firstValidityDate: "",
15
+ totalValue: 200
16
+ };
17
+ this.reserve = undefined;
18
+ this.cancel = undefined;
19
+ this.sliderPosition = 50;
20
+ }
21
+ componentWillLoad() {
22
+ this.usedValue = parseFloat(this.bonus.bonusBalance.toString());
23
+ this.buildPositionSlider(0, this.bonus.totalBonus);
24
+ }
25
+ handleSliderChange(event) {
26
+ const input = event.target;
27
+ this.usedValue = parseFloat(input.value);
28
+ // Calculando a posição do texto com base no valor do slider
29
+ // const percentage = ((this.usedValue - parseInt(input.min)) / (parseInt(input.max) - parseInt(input.min))) * 100;
30
+ // this.sliderPosition = percentage;
31
+ this.buildPositionSlider(parseFloat(input.min), parseFloat(input.max));
32
+ }
33
+ buildPositionSlider(min, max) {
34
+ // Calculando a posição do texto com base no valor do slider
35
+ const percentage = ((this.usedValue - min) / (max - min)) * 100;
36
+ this.sliderPosition = percentage;
37
+ }
38
+ async handleOptionChange(option) {
39
+ this.selectedOption = option;
40
+ switch (this.selectedOption) {
41
+ case 'use':
42
+ await this.reserve(this.usedValue);
43
+ break;
44
+ case 'dontUse':
45
+ await this.cancel();
46
+ break;
47
+ default:
48
+ }
49
+ }
50
+ render() {
51
+ const remainingGiftback = this.bonus.minimumPurchase - this.bonus.totalValue;
52
+ const translateDescription = i18next.t("giftDescription", { amount: `${this.bonus.totalBonus.toFixed(2).replace(".", ",")}`, custom_name: "Giftback" });
53
+ return (h("div", { key: 'fbc3b08d2e77fc7312ecbf24e9e785284c08ea86', class: "giftback-container" }, h("div", { key: '3717e46c93ad2dc4547a042ba159c3d28de64beb', class: "container-description" }, h("p", { key: '2acb0e117f873348cd819faec028f9d27736a106', innerHTML: translateDescription })), h("div", { key: '59c662da7f9b3070004ff7fe9a782a4714bff125', class: "slider-wrapper" }, h("div", { key: '4ed2c4049deb9d5c32f12b251cec2acd56446fa5', class: "slider-value", style: {
54
+ left: `calc(${this.sliderPosition}% - 20px)`, // Ajuste para centralizar o texto
55
+ } }, "R$ ", this.usedValue.toFixed(2).replace(".", ",")), h("input", { key: '1a73c61a7b2fc20932773b69147b27dc6ca0247b', type: "range", min: "0", max: this.bonus.totalBonus, value: this.usedValue, class: "slider", step: "0.01", onInput: (event) => this.handleSliderChange(event), style: {
56
+ background: `linear-gradient(to right, #6D6D5F ${this.sliderPosition}%, #ddd ${this.sliderPosition}%)`,
57
+ } })), h("p", { key: 'f490f6b4eb0adae75140b34e36694b49feb241ed' }, "Adicione ", h("strong", { key: 'a7b67ed94043d2d55cc9748c956c5516ce535245' }, "R$ ", remainingGiftback < 0 ? "0,00" : remainingGiftback.toFixed(2).replace(".", ",")), " ao carrinho para atingir o valor m\u00E1ximo!"), h("div", { key: 'd0ce836a492168e7f8439fbc3b1a7bca85305248', class: "options" }, h("label", { key: 'dd661987e7df0d967b4fe930c47144718d31b9f6' }, h("input", { key: '3201b786de110c3071d14af6134f61b9f1ede2c0', type: "radio", name: "giftbackOption", value: "use", checked: this.selectedOption === 'use', onChange: () => this.handleOptionChange('use') }), "Usar o meu Giftback"), h("label", { key: 'c7da572b125d4ae515e4ca026bc25815e0701712' }, h("input", { key: 'b6d1aee5626923f8cf49ae90114fb8e5c35e3fbf', type: "radio", name: "giftbackOption", value: "dontUse", checked: this.selectedOption === 'dontUse', onChange: () => this.handleOptionChange('dontUse') }), "N\u00E3o usar o meu Giftback")), h("div", { key: '577c1869fc4cb58d2817f0ab7fb2c18fae99ed66', class: "info-box" }, "O Giftback ser\u00E1 aplicado na pr\u00F3xima etapa.")));
58
+ }
59
+ static get is() { return "giftback-info"; }
60
+ static get originalStyleUrls() {
61
+ return {
62
+ "$": ["giftback-info.css"]
63
+ };
64
+ }
65
+ static get styleUrls() {
66
+ return {
67
+ "$": ["giftback-info.css"]
68
+ };
69
+ }
70
+ static get properties() {
71
+ return {
72
+ "loading": {
73
+ "type": "boolean",
74
+ "mutable": false,
75
+ "complexType": {
76
+ "original": "boolean",
77
+ "resolved": "boolean",
78
+ "references": {}
79
+ },
80
+ "required": false,
81
+ "optional": false,
82
+ "docs": {
83
+ "tags": [],
84
+ "text": ""
85
+ },
86
+ "attribute": "loading",
87
+ "reflect": false,
88
+ "defaultValue": "false"
89
+ },
90
+ "bonus": {
91
+ "type": "unknown",
92
+ "mutable": false,
93
+ "complexType": {
94
+ "original": "Partial<IBonus>",
95
+ "resolved": "{ hasBonus?: boolean; bonusBalance?: number; totalBonus?: number; minimumPurchase?: number; bonusIds?: string; firstValidityDate?: string; history?: [{ validityStart: string; validityEnd: string; value: number; }, { validityStart: string; validityEnd: string; value: number; }]; storeId?: number; userId?: number; cartId?: string; calculatedValue?: number; totalValue?: number; }",
96
+ "references": {
97
+ "Partial": {
98
+ "location": "global",
99
+ "id": "global::Partial"
100
+ },
101
+ "IBonus": {
102
+ "location": "import",
103
+ "path": "../../../../dto/validate.pin.bonus",
104
+ "id": "src/dto/validate.pin.bonus.ts::IBonus"
105
+ }
106
+ }
107
+ },
108
+ "required": false,
109
+ "optional": false,
110
+ "docs": {
111
+ "tags": [],
112
+ "text": ""
113
+ },
114
+ "defaultValue": "{\n totalBonus: 52,\n cartId: \"\",\n minimumPurchase: 6000,\n bonusBalance: 25,\n calculatedValue: 25,\n firstValidityDate: \"\",\n totalValue: 200\n }"
115
+ },
116
+ "reserve": {
117
+ "type": "unknown",
118
+ "mutable": false,
119
+ "complexType": {
120
+ "original": "(amountRedeemed: number) => void",
121
+ "resolved": "(amountRedeemed: number) => void",
122
+ "references": {}
123
+ },
124
+ "required": false,
125
+ "optional": false,
126
+ "docs": {
127
+ "tags": [],
128
+ "text": ""
129
+ }
130
+ },
131
+ "cancel": {
132
+ "type": "unknown",
133
+ "mutable": false,
134
+ "complexType": {
135
+ "original": "() => void",
136
+ "resolved": "() => void",
137
+ "references": {}
138
+ },
139
+ "required": false,
140
+ "optional": false,
141
+ "docs": {
142
+ "tags": [],
143
+ "text": ""
144
+ }
145
+ }
146
+ };
147
+ }
148
+ static get states() {
149
+ return {
150
+ "usedValue": {},
151
+ "selectedOption": {},
152
+ "sliderPosition": {}
153
+ };
154
+ }
155
+ }
156
+ //# sourceMappingURL=giftback-info.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"giftback-info.js","sourceRoot":"","sources":["../../../../../../src/components/giftback-form/subcomponents/giftback-info/giftback-info.tsx"],"names":[],"mappings":"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","sourcesContent":["import { Component, Prop, State, h } from \"@stencil/core\";\nimport { IBonus } from \"../../../../dto/validate.pin.bonus\";\n\nimport i18next from '../../../../i18n/i18n'\n\n@Component({\n tag: 'giftback-info',\n styleUrls: ['giftback-info.css']\n})\nexport class GiftbackInfo {\n @State() usedValue: number = 0;\n @State() selectedOption: string = 'none';\n\n @Prop() loading: boolean = false;\n @Prop() bonus: Partial<IBonus> = {\n totalBonus: 52,\n cartId: \"\",\n minimumPurchase: 6000,\n bonusBalance: 25,\n calculatedValue: 25,\n firstValidityDate: \"\",\n totalValue: 200\n };\n @Prop() reserve: (amountRedeemed: number) => void;\n @Prop() cancel: () => void;\n\n @State() sliderPosition: number = 50;\n\n componentWillLoad() {\n this.usedValue = parseFloat(this.bonus.bonusBalance.toString());\n\n this.buildPositionSlider(0, this.bonus.totalBonus);\n }\n\n handleSliderChange(event: Event) {\n const input = event.target as HTMLInputElement;\n this.usedValue = parseFloat(input.value);\n\n // Calculando a posição do texto com base no valor do slider\n // const percentage = ((this.usedValue - parseInt(input.min)) / (parseInt(input.max) - parseInt(input.min))) * 100;\n // this.sliderPosition = percentage;\n\n this.buildPositionSlider(parseFloat(input.min), parseFloat(input.max))\n }\n\n\n private buildPositionSlider(min:number, max: number) {\n // Calculando a posição do texto com base no valor do slider\n const percentage = ((this.usedValue - min) / (max - min)) * 100;\n this.sliderPosition = percentage;\n }\n\n async handleOptionChange(option: string) {\n this.selectedOption = option;\n switch (this.selectedOption) {\n case 'use':\n await this.reserve(this.usedValue)\n break;\n case 'dontUse':\n await this.cancel()\n break;\n default:\n }\n }\n render() {\n const remainingGiftback = this.bonus.minimumPurchase - this.bonus.totalValue;\n\n const translateDescription = i18next.t(\"giftDescription\", { amount: `${this.bonus.totalBonus.toFixed(2).replace(\".\", \",\")}`, custom_name: \"Giftback\" })\n\n return (\n\n <div class=\"giftback-container\">\n <div class=\"container-description\">\n <p innerHTML={translateDescription}></p>\n </div>\n <div class=\"slider-wrapper\">\n <div\n class=\"slider-value\"\n style={{\n left: `calc(${this.sliderPosition}% - 20px)`, // Ajuste para centralizar o texto\n }}\n >\n R$ {this.usedValue.toFixed(2).replace(\".\", \",\")}\n </div>\n <input\n type=\"range\"\n min=\"0\"\n max={this.bonus.totalBonus}\n value={this.usedValue}\n class=\"slider\"\n step=\"0.01\"\n onInput={(event) => this.handleSliderChange(event)}\n style={{\n background: `linear-gradient(to right, #6D6D5F ${this.sliderPosition}%, #ddd ${this.sliderPosition}%)`,\n }}\n />\n </div>\n <p>\n Adicione <strong>R$ {remainingGiftback < 0 ? \"0,00\" : remainingGiftback.toFixed(2).replace(\".\", \",\")}</strong> ao carrinho para atingir o valor\n máximo!\n </p>\n <div class=\"options\">\n <label>\n <input\n type=\"radio\"\n name=\"giftbackOption\"\n value=\"use\"\n checked={this.selectedOption === 'use'}\n onChange={() => this.handleOptionChange('use')}\n />\n Usar o meu Giftback\n </label>\n <label>\n <input\n type=\"radio\"\n name=\"giftbackOption\"\n value=\"dontUse\"\n checked={this.selectedOption === 'dontUse'}\n onChange={() => this.handleOptionChange('dontUse')}\n />\n Não usar o meu Giftback\n </label>\n </div>\n <div class=\"info-box\">\n O Giftback será aplicado na próxima etapa.\n </div>\n </div>\n );\n }\n}"]}