crmbonus-component-wake 1.0.46 → 2.0.47
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cjs/app-modal.cjs.entry.js +28 -0
- package/dist/cjs/app-modal.cjs.entry.js.map +1 -0
- package/dist/cjs/countdown-timer_4.cjs.entry.js +170 -0
- package/dist/cjs/countdown-timer_4.cjs.entry.js.map +1 -0
- package/dist/cjs/crm-bonus-form.cjs.entry.js +103 -0
- package/dist/cjs/crm-bonus-form.cjs.entry.js.map +1 -0
- package/dist/cjs/crm-bonus-note.cjs.entry.js +1 -1
- package/dist/cjs/crm-bonus.cjs.entry.js +39 -5
- package/dist/cjs/crm-bonus.cjs.entry.js.map +1 -1
- package/dist/cjs/crm-button.cjs.entry.js +24 -0
- package/dist/cjs/crm-button.cjs.entry.js.map +1 -0
- package/dist/cjs/crm-giftback-form.cjs.entry.js +108 -0
- package/dist/cjs/crm-giftback-form.cjs.entry.js.map +1 -0
- package/dist/cjs/crmbonus-component-wake.cjs.js +2 -2
- package/dist/cjs/giftback-finish_4.cjs.entry.js +5 -5
- package/dist/cjs/giftback-finish_4.cjs.entry.js.map +1 -1
- package/dist/cjs/i18n-db722856.js +2208 -0
- package/dist/cjs/i18n-db722856.js.map +1 -0
- package/dist/cjs/{index-52d8a075.js → index-80419303.js} +9 -4
- package/dist/cjs/index-80419303.js.map +1 -0
- package/dist/cjs/{index-861e0cbe.js → index-fdad75ce.js} +4 -1
- package/dist/cjs/index-fdad75ce.js.map +1 -0
- package/dist/cjs/loader.cjs.js +2 -2
- package/dist/cjs/loading-spinner.cjs.entry.js +2 -2
- package/dist/cjs/pedido-finalizado.cjs.entry.js +2 -2
- package/dist/cjs/phone-cancel-input.cjs.entry.js +25 -0
- package/dist/cjs/phone-cancel-input.cjs.entry.js.map +1 -0
- package/dist/cjs/phone-input-mask.cjs.entry.js +17 -4
- package/dist/cjs/phone-input-mask.cjs.entry.js.map +1 -1
- package/dist/cjs/phone-input.cjs.entry.js +25 -0
- package/dist/cjs/phone-input.cjs.entry.js.map +1 -0
- package/dist/collection/collection-manifest.json +6 -0
- package/dist/collection/components/button/crm-button.css +22 -0
- package/dist/collection/components/button/index.js +59 -0
- package/dist/collection/components/button/index.js.map +1 -1
- package/dist/collection/components/countdown-timer/countdown-timer.js +51 -0
- package/dist/collection/components/countdown-timer/countdown-timer.js.map +1 -0
- package/dist/collection/components/crm-bonus/crm-bonus.css +0 -3
- package/dist/collection/components/crm-bonus/crm-bonus.js +37 -3
- package/dist/collection/components/crm-bonus/crm-bonus.js.map +1 -1
- package/dist/collection/components/crm-bonus-form/crm-bonus-form.js +1 -1
- package/dist/collection/components/crm-bonus-form/subcomponents/giftback-finish/giftback-finish.js +1 -1
- package/dist/collection/components/crm-bonus-form/subcomponents/giftback-pin/giftback-pin.js +1 -1
- package/dist/collection/components/crm-bonus-form/subcomponents/giftback-progress/giftback-progress.css +1 -0
- package/dist/collection/components/crm-bonus-form/subcomponents/giftback-progress/giftback-progress.js +1 -1
- package/dist/collection/components/crm-bonus-form/subcomponents/name-input/name-input.js +1 -1
- package/dist/collection/components/crm-bonus-form/subcomponents/phone/phone.input.js +1 -1
- package/dist/collection/components/crm-bonus-form/subcomponents/phone-cancel/phone.cancel.input.js +1 -1
- package/dist/collection/components/giftback-form/giftback-form.css +47 -0
- package/dist/collection/components/giftback-form/giftback-form.js +182 -0
- package/dist/collection/components/giftback-form/giftback-form.js.map +1 -0
- package/dist/collection/components/giftback-form/subcomponents/giftback-info/giftback-info.css +152 -0
- package/dist/collection/components/giftback-form/subcomponents/giftback-info/giftback-info.js +143 -0
- package/dist/collection/components/giftback-form/subcomponents/giftback-info/giftback-info.js.map +1 -0
- package/dist/collection/components/giftback-form/subcomponents/phone-form/phone-form.js +80 -0
- package/dist/collection/components/giftback-form/subcomponents/phone-form/phone-form.js.map +1 -0
- package/dist/collection/components/giftback-form/subcomponents/pin-form/pin-form.css +87 -0
- package/dist/collection/components/giftback-form/subcomponents/pin-form/pin-form.js +180 -0
- package/dist/collection/components/giftback-form/subcomponents/pin-form/pin-form.js.map +1 -0
- package/dist/collection/components/loading-spinner/loading-spinner.js +1 -1
- package/dist/collection/components/modal/app-modal.js +1 -1
- package/dist/collection/components/pedido/pedido.js +1 -1
- package/dist/collection/components/phone/phone-input-mask.css +18 -39
- package/dist/collection/components/phone/phone-input-mask.js +17 -3
- package/dist/collection/components/phone/phone-input-mask.js.map +1 -1
- package/dist/collection/contants/index.js +1 -0
- package/dist/collection/contants/index.js.map +1 -1
- package/dist/collection/i18n/i18n.js +24 -0
- package/dist/collection/i18n/i18n.js.map +1 -0
- package/dist/components/app-modal.js +39 -1
- package/dist/components/app-modal.js.map +1 -1
- package/dist/components/countdown-timer.d.ts +11 -0
- package/dist/components/countdown-timer.js +8 -0
- package/dist/components/countdown-timer.js.map +1 -0
- package/dist/components/crm-bonus-form.js +158 -1
- package/dist/components/crm-bonus-form.js.map +1 -1
- package/dist/components/crm-bonus-note.js +1 -1
- package/dist/components/crm-bonus.js +56 -33
- package/dist/components/crm-bonus.js.map +1 -1
- package/dist/components/crm-button.d.ts +11 -0
- package/dist/components/crm-button.js +8 -0
- package/dist/components/crm-button.js.map +1 -0
- package/dist/components/crm-giftback-form.d.ts +11 -0
- package/dist/components/crm-giftback-form.js +8 -0
- package/dist/components/crm-giftback-form.js.map +1 -0
- package/dist/components/giftback-finish.js +1 -1
- package/dist/components/giftback-info.d.ts +11 -0
- package/dist/components/giftback-info.js +8 -0
- package/dist/components/giftback-info.js.map +1 -0
- package/dist/components/giftback-pin.js +1 -1
- package/dist/components/giftback-progress.js +1 -1
- package/dist/components/index.js +1 -1
- package/dist/components/loading-spinner.js +1 -1
- package/dist/components/name-input.js +1 -1
- package/dist/components/{p-0e99f907.js → p-0c1aa75b.js} +4 -4
- package/dist/components/{p-0e99f907.js.map → p-0c1aa75b.js.map} +1 -1
- package/dist/components/p-1539def7.js +44 -0
- package/dist/components/p-1539def7.js.map +1 -0
- package/dist/components/{p-faf7103e.js → p-2f266d73.js} +6 -2
- package/dist/components/p-2f266d73.js.map +1 -0
- package/dist/components/p-39d680b6.js +49 -0
- package/dist/components/p-39d680b6.js.map +1 -0
- package/dist/components/p-7e8a1832.js +76 -0
- package/dist/components/p-7e8a1832.js.map +1 -0
- package/dist/components/p-9a435c31.js +79 -0
- package/dist/components/p-9a435c31.js.map +1 -0
- package/dist/components/p-a7e91243.js +2206 -0
- package/dist/components/p-a7e91243.js.map +1 -0
- package/dist/components/p-b1841bad.js +62 -0
- package/dist/components/p-b1841bad.js.map +1 -0
- package/dist/components/p-bc925ed6.js +112 -0
- package/dist/components/p-bc925ed6.js.map +1 -0
- package/dist/components/{p-ddc0ac71.js → p-bf93729e.js} +3 -3
- package/dist/components/{p-ddc0ac71.js.map → p-bf93729e.js.map} +1 -1
- package/dist/{esm/index-ea02697e.js → components/p-dddd9ee6.js} +3 -2
- package/dist/components/p-dddd9ee6.js.map +1 -0
- package/dist/components/{p-19b83423.js → p-e443d670.js} +4 -4
- package/dist/components/{p-19b83423.js.map → p-e443d670.js.map} +1 -1
- package/dist/components/{p-e2727638.js → p-f2ab4eea.js} +4 -4
- package/dist/components/p-f2ab4eea.js.map +1 -0
- package/dist/components/{p-530006e6.js → p-f5fcff75.js} +3 -3
- package/dist/components/{p-530006e6.js.map → p-f5fcff75.js.map} +1 -1
- package/dist/components/p-f8b4698f.js +174 -0
- package/dist/components/p-f8b4698f.js.map +1 -0
- package/dist/components/pedido-finalizado.js +2 -2
- package/dist/components/phone-cancel-input.js +48 -1
- package/dist/components/phone-cancel-input.js.map +1 -1
- package/dist/components/phone-form.d.ts +11 -0
- package/dist/components/phone-form.js +8 -0
- package/dist/components/phone-form.js.map +1 -0
- package/dist/components/phone-input-mask.js +1 -1
- package/dist/components/phone-input.js +48 -1
- package/dist/components/phone-input.js.map +1 -1
- package/dist/components/pin-form.d.ts +11 -0
- package/dist/components/pin-form.js +8 -0
- package/dist/components/pin-form.js.map +1 -0
- package/dist/crmbonus-component-wake/crmbonus-component-wake.css +1 -0
- package/dist/crmbonus-component-wake/crmbonus-component-wake.esm.js +1 -1
- package/dist/crmbonus-component-wake/crmbonus-component-wake.esm.js.map +1 -1
- package/dist/crmbonus-component-wake/{p-2636f2f0.entry.js → p-574108d2.entry.js} +2 -2
- package/dist/crmbonus-component-wake/p-574108d2.entry.js.map +1 -0
- package/dist/crmbonus-component-wake/p-5ede3b10.entry.js +2 -0
- package/dist/crmbonus-component-wake/p-5ede3b10.entry.js.map +1 -0
- package/dist/crmbonus-component-wake/p-61462d71.entry.js +2 -0
- package/dist/crmbonus-component-wake/p-61462d71.entry.js.map +1 -0
- package/dist/crmbonus-component-wake/p-63d2a359.entry.js +2 -0
- package/dist/crmbonus-component-wake/p-63d2a359.entry.js.map +1 -0
- package/dist/crmbonus-component-wake/p-6e6bf96e.js +3 -0
- package/dist/crmbonus-component-wake/p-6e6bf96e.js.map +1 -0
- package/dist/crmbonus-component-wake/p-7aff6c4e.entry.js +2 -0
- package/dist/crmbonus-component-wake/p-7aff6c4e.entry.js.map +1 -0
- package/dist/crmbonus-component-wake/p-83182e85.entry.js +2 -0
- package/dist/crmbonus-component-wake/p-83182e85.entry.js.map +1 -0
- package/dist/crmbonus-component-wake/p-8b9a1aec.entry.js +2 -0
- package/dist/crmbonus-component-wake/p-8b9a1aec.entry.js.map +1 -0
- package/dist/crmbonus-component-wake/p-a7e91243.js +2 -0
- package/dist/crmbonus-component-wake/p-a7e91243.js.map +1 -0
- package/dist/crmbonus-component-wake/p-adb37e26.entry.js +2 -0
- package/dist/crmbonus-component-wake/p-adb37e26.entry.js.map +1 -0
- package/dist/crmbonus-component-wake/p-be553772.entry.js +2 -0
- package/dist/crmbonus-component-wake/p-be553772.entry.js.map +1 -0
- package/dist/crmbonus-component-wake/{p-a01c57ab.entry.js → p-cdd018cc.entry.js} +2 -2
- package/dist/crmbonus-component-wake/{p-001e3e2b.entry.js → p-d6af7631.entry.js} +2 -2
- package/dist/crmbonus-component-wake/{p-9b967605.js → p-dddd9ee6.js} +2 -2
- package/dist/crmbonus-component-wake/p-dddd9ee6.js.map +1 -0
- package/dist/crmbonus-component-wake/{p-5febaa3c.entry.js → p-e23e8d6d.entry.js} +2 -2
- package/dist/crmbonus-component-wake/p-e3b52362.entry.js +2 -0
- package/dist/crmbonus-component-wake/p-e3b52362.entry.js.map +1 -0
- package/dist/esm/app-modal.entry.js +24 -0
- package/dist/esm/app-modal.entry.js.map +1 -0
- package/dist/esm/countdown-timer_4.entry.js +163 -0
- package/dist/esm/countdown-timer_4.entry.js.map +1 -0
- package/dist/esm/crm-bonus-form.entry.js +99 -0
- package/dist/esm/crm-bonus-form.entry.js.map +1 -0
- package/dist/esm/crm-bonus-note.entry.js +1 -1
- package/dist/esm/crm-bonus.entry.js +39 -5
- package/dist/esm/crm-bonus.entry.js.map +1 -1
- package/dist/esm/crm-button.entry.js +20 -0
- package/dist/esm/crm-button.entry.js.map +1 -0
- package/dist/esm/crm-giftback-form.entry.js +104 -0
- package/dist/esm/crm-giftback-form.entry.js.map +1 -0
- package/dist/esm/crmbonus-component-wake.js +3 -3
- package/dist/esm/giftback-finish_4.entry.js +5 -5
- package/dist/esm/giftback-finish_4.entry.js.map +1 -1
- package/dist/esm/i18n-d8b777a9.js +2206 -0
- package/dist/esm/i18n-d8b777a9.js.map +1 -0
- package/dist/esm/index-7101ea0c.js +13 -0
- package/dist/esm/index-7101ea0c.js.map +1 -0
- package/dist/esm/{index-9f7bde48.js → index-a4c14fca.js} +9 -4
- package/dist/esm/index-a4c14fca.js.map +1 -0
- package/dist/esm/loader.js +3 -3
- package/dist/esm/loading-spinner.entry.js +2 -2
- package/dist/esm/pedido-finalizado.entry.js +2 -2
- package/dist/esm/phone-cancel-input.entry.js +21 -0
- package/dist/esm/phone-cancel-input.entry.js.map +1 -0
- package/dist/esm/phone-input-mask.entry.js +17 -4
- package/dist/esm/phone-input-mask.entry.js.map +1 -1
- package/dist/esm/phone-input.entry.js +21 -0
- package/dist/esm/phone-input.entry.js.map +1 -0
- package/dist/types/components/button/index.d.ts +5 -0
- package/dist/types/components/countdown-timer/countdown-timer.d.ts +8 -0
- package/dist/types/components/giftback-form/giftback-form.d.ts +24 -0
- package/dist/types/components/giftback-form/subcomponents/giftback-info/giftback-info.d.ts +15 -0
- package/dist/types/components/giftback-form/subcomponents/phone-form/phone-form.d.ts +8 -0
- package/dist/types/components/giftback-form/subcomponents/pin-form/pin-form.d.ts +20 -0
- package/dist/types/components/phone/phone-input-mask.d.ts +2 -0
- package/dist/types/components.d.ts +116 -0
- package/dist/types/contants/index.d.ts +1 -0
- package/dist/types/i18n/i18n.d.ts +2 -0
- package/package.json +3 -2
- package/dist/cjs/app-modal_4.cjs.entry.js +0 -157
- package/dist/cjs/app-modal_4.cjs.entry.js.map +0 -1
- package/dist/cjs/index-52d8a075.js.map +0 -1
- package/dist/cjs/index-861e0cbe.js.map +0 -1
- package/dist/components/p-03c2447c.js +0 -170
- package/dist/components/p-03c2447c.js.map +0 -1
- package/dist/components/p-1dbb0f43.js +0 -43
- package/dist/components/p-1dbb0f43.js.map +0 -1
- package/dist/components/p-3c29c6ad.js +0 -62
- package/dist/components/p-3c29c6ad.js.map +0 -1
- package/dist/components/p-41d42a66.js +0 -52
- package/dist/components/p-41d42a66.js.map +0 -1
- package/dist/components/p-6c553ee7.js +0 -52
- package/dist/components/p-6c553ee7.js.map +0 -1
- package/dist/components/p-e2727638.js.map +0 -1
- package/dist/components/p-faf7103e.js.map +0 -1
- package/dist/crmbonus-component-wake/p-2636f2f0.entry.js.map +0 -1
- package/dist/crmbonus-component-wake/p-3582baf8.entry.js +0 -2
- package/dist/crmbonus-component-wake/p-3582baf8.entry.js.map +0 -1
- package/dist/crmbonus-component-wake/p-61df4eb6.entry.js +0 -2
- package/dist/crmbonus-component-wake/p-61df4eb6.entry.js.map +0 -1
- package/dist/crmbonus-component-wake/p-72510682.js +0 -3
- package/dist/crmbonus-component-wake/p-72510682.js.map +0 -1
- package/dist/crmbonus-component-wake/p-9b967605.js.map +0 -1
- package/dist/crmbonus-component-wake/p-dbb64825.entry.js +0 -2
- package/dist/crmbonus-component-wake/p-dbb64825.entry.js.map +0 -1
- package/dist/esm/app-modal_4.entry.js +0 -150
- package/dist/esm/app-modal_4.entry.js.map +0 -1
- package/dist/esm/index-9f7bde48.js.map +0 -1
- package/dist/esm/index-ea02697e.js.map +0 -1
- /package/dist/crmbonus-component-wake/{p-a01c57ab.entry.js.map → p-cdd018cc.entry.js.map} +0 -0
- /package/dist/crmbonus-component-wake/{p-001e3e2b.entry.js.map → p-d6af7631.entry.js.map} +0 -0
- /package/dist/crmbonus-component-wake/{p-5febaa3c.entry.js.map → p-e23e8d6d.entry.js.map} +0 -0
@@ -0,0 +1,182 @@
|
|
1
|
+
import { h } from "@stencil/core";
|
2
|
+
import { CrmBonusService } from "../../services/crmbonus.service";
|
3
|
+
import { StepFormEnum } from "../../contants";
|
4
|
+
export class CrmBonus {
|
5
|
+
constructor() {
|
6
|
+
// private phoneInputMask: HTMLPhoneFormElement;
|
7
|
+
this.crmBonusService = CrmBonusService.getInstance();
|
8
|
+
this.storeName = undefined;
|
9
|
+
this.cartId = undefined;
|
10
|
+
this.products = undefined;
|
11
|
+
this.value = undefined;
|
12
|
+
this.loading = false;
|
13
|
+
this.message = undefined;
|
14
|
+
this.phone = undefined;
|
15
|
+
this.pinInfo = undefined;
|
16
|
+
this.step = StepFormEnum.STEP_RESERVE;
|
17
|
+
this.bonus = undefined;
|
18
|
+
this.sucess = "";
|
19
|
+
this.error = "";
|
20
|
+
}
|
21
|
+
async handleSendPin(phone) {
|
22
|
+
this.message = "";
|
23
|
+
if (!phone) {
|
24
|
+
this.message = "Informe seu telefone";
|
25
|
+
return;
|
26
|
+
}
|
27
|
+
this.phone = phone;
|
28
|
+
this.sendPin();
|
29
|
+
}
|
30
|
+
convertStringToNumber() {
|
31
|
+
const _phone = this.phone.replace(/\D/g, '');
|
32
|
+
return Number(_phone);
|
33
|
+
}
|
34
|
+
async sendPin() {
|
35
|
+
var _a, _b;
|
36
|
+
this.loading = true;
|
37
|
+
this.message = "";
|
38
|
+
try {
|
39
|
+
const _phone = this.convertStringToNumber();
|
40
|
+
this.pinInfo = await this.crmBonusService.sendPin(_phone, "", this.storeName);
|
41
|
+
this.step = StepFormEnum.STEP_PIN;
|
42
|
+
}
|
43
|
+
catch (error) {
|
44
|
+
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;
|
45
|
+
}
|
46
|
+
finally {
|
47
|
+
this.loading = false;
|
48
|
+
}
|
49
|
+
}
|
50
|
+
changePhone() {
|
51
|
+
this.step = StepFormEnum.STEP_PHONE;
|
52
|
+
}
|
53
|
+
async validateBonus(pin) {
|
54
|
+
var _a, _b;
|
55
|
+
if (this.sucess) {
|
56
|
+
this.step = StepFormEnum.STEP_RESERVE;
|
57
|
+
return;
|
58
|
+
}
|
59
|
+
this.loading = true;
|
60
|
+
this.sucess = "";
|
61
|
+
this.error = "";
|
62
|
+
const payload = {
|
63
|
+
pin: pin,
|
64
|
+
cellphone: this.phone.toString(),
|
65
|
+
storeId: this.pinInfo.storeId.toString(),
|
66
|
+
userId: this.pinInfo.userId.toString(),
|
67
|
+
checkoutId: this.cartId,
|
68
|
+
checkoutProducts: this.products,
|
69
|
+
name: null,
|
70
|
+
storeName: this.storeName
|
71
|
+
};
|
72
|
+
try {
|
73
|
+
this.bonus = await this.crmBonusService.validatePinBonus(payload);
|
74
|
+
this.sucess = "Código validado com sucesso!";
|
75
|
+
}
|
76
|
+
catch (error) {
|
77
|
+
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;
|
78
|
+
if (_error.includes("Pin")) {
|
79
|
+
this.error = "Código inválido!";
|
80
|
+
}
|
81
|
+
else {
|
82
|
+
this.error = _error;
|
83
|
+
}
|
84
|
+
}
|
85
|
+
finally {
|
86
|
+
this.loading = false;
|
87
|
+
}
|
88
|
+
}
|
89
|
+
render() {
|
90
|
+
return (h("div", { key: '880d793d0f50f74aa844cc1e2bd7da9963e43d93', class: "crm-container-form" }, h("label", { key: '4bd61d9cf4cad1822da4f4c975c824feae3a023d', class: "crm-title" }, "Giftback"), this.step === StepFormEnum.STEP_PHONE &&
|
91
|
+
h("phone-form", { key: 'd259d5c3f0660c76dd431059f50f2dec10ec3987', loading: this.loading, handlerSubmit: (phone) => this.handleSendPin(phone) }), this.step === StepFormEnum.STEP_PIN &&
|
92
|
+
h("pin-form", { key: '28e3faa8c2c5dece718466ee0039eb91d0add3f4', phone: this.phone, cancel: () => this.changePhone(), resend: () => this.sendPin(), validate: (data) => this.validateBonus(data), loading: this.loading }, this.sucess && h("p", { key: '9b1082db2b2d1a4c704c1dd72e3fde40d373e837', class: "crm-message-info" }, this.sucess), this.error && h("p", { key: '46689dfdb9af83e1450779ff6aee41724dca7090', class: "crm-message-error" }, this.error)), this.step === StepFormEnum.STEP_RESERVE && h("giftback-info", { key: 'd0e4963c1541865ce83d18b2c07f620d8d7d21f9' })));
|
93
|
+
}
|
94
|
+
static get is() { return "crm-giftback-form"; }
|
95
|
+
static get originalStyleUrls() {
|
96
|
+
return {
|
97
|
+
"$": ["giftback-form.css"]
|
98
|
+
};
|
99
|
+
}
|
100
|
+
static get styleUrls() {
|
101
|
+
return {
|
102
|
+
"$": ["giftback-form.css"]
|
103
|
+
};
|
104
|
+
}
|
105
|
+
static get properties() {
|
106
|
+
return {
|
107
|
+
"storeName": {
|
108
|
+
"type": "any",
|
109
|
+
"mutable": false,
|
110
|
+
"complexType": {
|
111
|
+
"original": "any",
|
112
|
+
"resolved": "any",
|
113
|
+
"references": {}
|
114
|
+
},
|
115
|
+
"required": false,
|
116
|
+
"optional": false,
|
117
|
+
"docs": {
|
118
|
+
"tags": [],
|
119
|
+
"text": ""
|
120
|
+
},
|
121
|
+
"attribute": "storename",
|
122
|
+
"reflect": false
|
123
|
+
},
|
124
|
+
"cartId": {
|
125
|
+
"type": "any",
|
126
|
+
"mutable": false,
|
127
|
+
"complexType": {
|
128
|
+
"original": "any",
|
129
|
+
"resolved": "any",
|
130
|
+
"references": {}
|
131
|
+
},
|
132
|
+
"required": false,
|
133
|
+
"optional": false,
|
134
|
+
"docs": {
|
135
|
+
"tags": [],
|
136
|
+
"text": ""
|
137
|
+
},
|
138
|
+
"attribute": "cart-id",
|
139
|
+
"reflect": false
|
140
|
+
},
|
141
|
+
"products": {
|
142
|
+
"type": "unknown",
|
143
|
+
"mutable": false,
|
144
|
+
"complexType": {
|
145
|
+
"original": "Array<IProduct>",
|
146
|
+
"resolved": "IProduct[]",
|
147
|
+
"references": {
|
148
|
+
"Array": {
|
149
|
+
"location": "global",
|
150
|
+
"id": "global::Array"
|
151
|
+
},
|
152
|
+
"IProduct": {
|
153
|
+
"location": "import",
|
154
|
+
"path": "../../dto/validate.pin.bonus",
|
155
|
+
"id": "src/dto/validate.pin.bonus.ts::IProduct"
|
156
|
+
}
|
157
|
+
}
|
158
|
+
},
|
159
|
+
"required": false,
|
160
|
+
"optional": false,
|
161
|
+
"docs": {
|
162
|
+
"tags": [],
|
163
|
+
"text": ""
|
164
|
+
}
|
165
|
+
}
|
166
|
+
};
|
167
|
+
}
|
168
|
+
static get states() {
|
169
|
+
return {
|
170
|
+
"value": {},
|
171
|
+
"loading": {},
|
172
|
+
"message": {},
|
173
|
+
"phone": {},
|
174
|
+
"pinInfo": {},
|
175
|
+
"step": {},
|
176
|
+
"bonus": {},
|
177
|
+
"sucess": {},
|
178
|
+
"error": {}
|
179
|
+
};
|
180
|
+
}
|
181
|
+
}
|
182
|
+
//# 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\";\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_RESERVE;\n @State() bonus: IBonus;\n\n @State() sucess: string = \"\";\n @State() error: string = \"\";\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 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\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.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 } finally {\n this.loading = false;\n }\n }\n\n render() {\n return (\n <div class=\"crm-container-form\" >\n <label class=\"crm-title\">Giftback</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 {this.step === StepFormEnum.STEP_RESERVE && <giftback-info />}\n </div>\n )\n }\n}"]}
|
package/dist/collection/components/giftback-form/subcomponents/giftback-info/giftback-info.css
ADDED
@@ -0,0 +1,152 @@
|
|
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: 2px;
|
42
|
+
outline: none;
|
43
|
+
}
|
44
|
+
|
45
|
+
input[type='range']::-webkit-slider-thumb {
|
46
|
+
-webkit-appearance: none;
|
47
|
+
appearance: none;
|
48
|
+
width: 16px;
|
49
|
+
height: 16px;
|
50
|
+
background: var(--text-color);
|
51
|
+
/* Azul para o slider */
|
52
|
+
border-radius: 50%;
|
53
|
+
cursor: pointer;
|
54
|
+
}
|
55
|
+
|
56
|
+
.options {
|
57
|
+
margin: 0px 0;
|
58
|
+
display: flex;
|
59
|
+
gap: 10px;
|
60
|
+
flex-direction: column;
|
61
|
+
}
|
62
|
+
|
63
|
+
.options label {
|
64
|
+
display: block;
|
65
|
+
margin: 0px 0;
|
66
|
+
font-size: 0.9rem;
|
67
|
+
color: #333;
|
68
|
+
}
|
69
|
+
|
70
|
+
.options input[type='radio'] {
|
71
|
+
margin-right: 8px;
|
72
|
+
height: 16px;
|
73
|
+
width: 16px;
|
74
|
+
}
|
75
|
+
|
76
|
+
.options input[type='radio'] {
|
77
|
+
appearance: none;
|
78
|
+
-webkit-appearance: none;
|
79
|
+
margin-right: 8px;
|
80
|
+
width: 16px;
|
81
|
+
height: 16px;
|
82
|
+
border: 2px solid #ddd;
|
83
|
+
border-radius: 50%;
|
84
|
+
background-color: #fff;
|
85
|
+
cursor: pointer;
|
86
|
+
transition: all 0.3s;
|
87
|
+
}
|
88
|
+
|
89
|
+
.options input[type='radio']:checked {
|
90
|
+
border-color: #000;
|
91
|
+
background-color: #FAFAFA;
|
92
|
+
border: 4px solid #000;
|
93
|
+
}
|
94
|
+
|
95
|
+
.info-box {
|
96
|
+
background-color: #f9f9f9;
|
97
|
+
border: 1px solid #e0e0e0;
|
98
|
+
border-radius: 4px;
|
99
|
+
padding: 8px;
|
100
|
+
font-size: 14px;
|
101
|
+
color: #262626;
|
102
|
+
line-height: 20px;
|
103
|
+
}
|
104
|
+
|
105
|
+
.info-icon {
|
106
|
+
font-size: 0.9rem;
|
107
|
+
cursor: pointer;
|
108
|
+
color: #888;
|
109
|
+
}
|
110
|
+
|
111
|
+
h3 {
|
112
|
+
font-size: 1.2rem;
|
113
|
+
margin-bottom: 8px;
|
114
|
+
color: #333;
|
115
|
+
}
|
116
|
+
|
117
|
+
.slider-wrapper {
|
118
|
+
position: relative;
|
119
|
+
margin: 21px 0px 0px 0px;
|
120
|
+
}
|
121
|
+
|
122
|
+
.slider {
|
123
|
+
width: 100%;
|
124
|
+
-webkit-appearance: none;
|
125
|
+
background: #ddd;
|
126
|
+
height: 4px;
|
127
|
+
border-radius: 2px;
|
128
|
+
outline: none;
|
129
|
+
}
|
130
|
+
|
131
|
+
.slider::-webkit-slider-thumb {
|
132
|
+
-webkit-appearance: none;
|
133
|
+
appearance: none;
|
134
|
+
width: 16px;
|
135
|
+
height: 16px;
|
136
|
+
background: var(--text-color);
|
137
|
+
/* Azul para o slider */
|
138
|
+
border-radius: 50%;
|
139
|
+
cursor: pointer;
|
140
|
+
}
|
141
|
+
|
142
|
+
.slider-value {
|
143
|
+
position: absolute;
|
144
|
+
top: -30px;
|
145
|
+
/* Posição acima do slider */
|
146
|
+
font-size: 16px;
|
147
|
+
font-weight: 700;
|
148
|
+
color: var(--text-color);
|
149
|
+
/* Verde para o texto */
|
150
|
+
transform: translateX(-50%);
|
151
|
+
white-space: nowrap;
|
152
|
+
}
|
@@ -0,0 +1,143 @@
|
|
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
|
+
}
|
24
|
+
handleSliderChange(event) {
|
25
|
+
const input = event.target;
|
26
|
+
this.usedValue = parseFloat(input.value);
|
27
|
+
// Calculando a posição do texto com base no valor do slider
|
28
|
+
const percentage = ((this.usedValue - parseInt(input.min)) / (parseInt(input.max) - parseInt(input.min))) * 100;
|
29
|
+
this.sliderPosition = percentage;
|
30
|
+
}
|
31
|
+
async handleReserve(value) {
|
32
|
+
this.reserve(value);
|
33
|
+
}
|
34
|
+
handleOptionChange(option) {
|
35
|
+
this.selectedOption = option;
|
36
|
+
}
|
37
|
+
render() {
|
38
|
+
const remainingGiftback = this.bonus.minimumPurchase - this.bonus.totalValue;
|
39
|
+
const translateDescription = i18next.t("giftDescription", { amount: `${this.bonus.totalBonus.toFixed(2).replace(".", ",")}`, custom_name: "Giftback" });
|
40
|
+
return (h("div", { key: '5216b7254293a9ad3a85d58cb6273a2f0ae49fff', class: "giftback-container" }, h("div", { key: 'ec8783d5e419381740dd23fc03e3d8b12654d902', class: "container-description" }, h("p", { key: '4d98d2611555d5ce759db49d84edb140b9cee319', innerHTML: translateDescription })), h("div", { key: 'ca252ce325af406a166b054d2622f534e5a3219a', class: "slider-wrapper" }, h("div", { key: '594c87917a88556b41672c95699afa861e6028ca', class: "slider-value", style: {
|
41
|
+
left: `calc(${this.sliderPosition}% - 20px)`, // Ajuste para centralizar o texto
|
42
|
+
} }, "R$ ", this.usedValue.toFixed(2).replace(".", ",")), h("input", { key: '02d30afa37f8e9a17f07cdd278eba0a512896e2f', type: "range", min: "0", max: this.bonus.totalBonus, value: this.usedValue, class: "slider", step: "0.01", onInput: (event) => this.handleSliderChange(event), style: {
|
43
|
+
background: `linear-gradient(to right, #6D6D5F ${this.sliderPosition}%, #ddd ${this.sliderPosition}%)`,
|
44
|
+
} })), h("p", { key: '60bccd302674a410b09f40805b62e230c0f36b3a' }, "Adicione ", h("strong", { key: '2b3dead9f0ed56b1356087caeceb4d484bb85212' }, "R$ ", remainingGiftback.toFixed(2).replace(".", ",")), " ao carrinho para atingir o valor m\u00E1ximo!"), h("div", { key: '2c8883e5fc247438991933f34e1de0b5f10b0b4c', class: "options" }, h("label", { key: '30612fadf2be708974147b1777dd710dc7669787' }, h("input", { key: 'a945ba180a170ac45d929a2868eb0a83d8d9a7f0', type: "radio", name: "giftbackOption", value: "use", checked: this.selectedOption === 'use', onChange: () => this.handleOptionChange('use') }), "Usar o meu Giftback"), h("label", { key: '7fd8fe57cef4920a340df40a794c275e6f1e10e2' }, h("input", { key: 'f29ae7491b3574abb2ae5f109538f1c125f14370', type: "radio", name: "giftbackOption", value: "dontUse", checked: this.selectedOption === 'dontUse', onChange: () => this.handleOptionChange('dontUse') }), "N\u00E3o usar o meu Giftback")), h("div", { key: '4eb475d5c0c4e8219c68c159ff24abf0c1c73a70', class: "info-box" }, "O Giftback ser\u00E1 aplicado na pr\u00F3xima etapa.")));
|
45
|
+
}
|
46
|
+
static get is() { return "giftback-info"; }
|
47
|
+
static get originalStyleUrls() {
|
48
|
+
return {
|
49
|
+
"$": ["giftback-info.css"]
|
50
|
+
};
|
51
|
+
}
|
52
|
+
static get styleUrls() {
|
53
|
+
return {
|
54
|
+
"$": ["giftback-info.css"]
|
55
|
+
};
|
56
|
+
}
|
57
|
+
static get properties() {
|
58
|
+
return {
|
59
|
+
"loading": {
|
60
|
+
"type": "boolean",
|
61
|
+
"mutable": false,
|
62
|
+
"complexType": {
|
63
|
+
"original": "boolean",
|
64
|
+
"resolved": "boolean",
|
65
|
+
"references": {}
|
66
|
+
},
|
67
|
+
"required": false,
|
68
|
+
"optional": false,
|
69
|
+
"docs": {
|
70
|
+
"tags": [],
|
71
|
+
"text": ""
|
72
|
+
},
|
73
|
+
"attribute": "loading",
|
74
|
+
"reflect": false,
|
75
|
+
"defaultValue": "false"
|
76
|
+
},
|
77
|
+
"bonus": {
|
78
|
+
"type": "unknown",
|
79
|
+
"mutable": false,
|
80
|
+
"complexType": {
|
81
|
+
"original": "Partial<IBonus>",
|
82
|
+
"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; }",
|
83
|
+
"references": {
|
84
|
+
"Partial": {
|
85
|
+
"location": "global",
|
86
|
+
"id": "global::Partial"
|
87
|
+
},
|
88
|
+
"IBonus": {
|
89
|
+
"location": "import",
|
90
|
+
"path": "../../../../dto/validate.pin.bonus",
|
91
|
+
"id": "src/dto/validate.pin.bonus.ts::IBonus"
|
92
|
+
}
|
93
|
+
}
|
94
|
+
},
|
95
|
+
"required": false,
|
96
|
+
"optional": false,
|
97
|
+
"docs": {
|
98
|
+
"tags": [],
|
99
|
+
"text": ""
|
100
|
+
},
|
101
|
+
"defaultValue": "{\n totalBonus: 52,\n cartId: \"\",\n minimumPurchase: 6000,\n bonusBalance: 25,\n calculatedValue: 25,\n firstValidityDate: \"\",\n totalValue: 200\n }"
|
102
|
+
},
|
103
|
+
"reserve": {
|
104
|
+
"type": "unknown",
|
105
|
+
"mutable": false,
|
106
|
+
"complexType": {
|
107
|
+
"original": "(amountRedeemed: number) => void",
|
108
|
+
"resolved": "(amountRedeemed: number) => void",
|
109
|
+
"references": {}
|
110
|
+
},
|
111
|
+
"required": false,
|
112
|
+
"optional": false,
|
113
|
+
"docs": {
|
114
|
+
"tags": [],
|
115
|
+
"text": ""
|
116
|
+
}
|
117
|
+
},
|
118
|
+
"cancel": {
|
119
|
+
"type": "unknown",
|
120
|
+
"mutable": false,
|
121
|
+
"complexType": {
|
122
|
+
"original": "() => void",
|
123
|
+
"resolved": "() => void",
|
124
|
+
"references": {}
|
125
|
+
},
|
126
|
+
"required": false,
|
127
|
+
"optional": false,
|
128
|
+
"docs": {
|
129
|
+
"tags": [],
|
130
|
+
"text": ""
|
131
|
+
}
|
132
|
+
}
|
133
|
+
};
|
134
|
+
}
|
135
|
+
static get states() {
|
136
|
+
return {
|
137
|
+
"usedValue": {},
|
138
|
+
"selectedOption": {},
|
139
|
+
"sliderPosition": {}
|
140
|
+
};
|
141
|
+
}
|
142
|
+
}
|
143
|
+
//# sourceMappingURL=giftback-info.js.map
|
package/dist/collection/components/giftback-form/subcomponents/giftback-info/giftback-info.js.map
ADDED
@@ -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\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\n async handleReserve(value: number) {\n this.reserve(value);\n }\n\n handleOptionChange(option: string) {\n this.selectedOption = option;\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.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}"]}
|
@@ -0,0 +1,80 @@
|
|
1
|
+
import { Host, h } from "@stencil/core";
|
2
|
+
export class PhoneForm {
|
3
|
+
constructor() {
|
4
|
+
this.value = undefined;
|
5
|
+
this.loading = undefined;
|
6
|
+
this.handlerSubmit = undefined;
|
7
|
+
}
|
8
|
+
async handlePhone() {
|
9
|
+
const phone = await this.phoneInputMask.getPhone();
|
10
|
+
await this.handlerSubmit(phone);
|
11
|
+
}
|
12
|
+
render() {
|
13
|
+
return (h(Host, { key: 'f2ed303c01b92b39fe770bc6eee8a6134975e021', class: "crm-phone-form" }, h("label", { key: 'c2dd99890b17100ce496fd534fbdb22a78eb2897', class: "crm-subtitle" }, "Digite o seu celular para verificar se h\u00E1 desconto dispon\u00EDvel nessa compra"), h("phone-input-mask", { key: '7db87cef288dff4234400dc27e34b8341bdd1b42', initialValue: this.value, ref: ref => this.phoneInputMask = ref }), h("crm-button", { key: '47d08602ed469e9aeca5c633bef2f7b2020e88f1', txtBtn: "Avan\u00E7ar", loading: this.loading, onClick: () => this.handlePhone() })));
|
14
|
+
}
|
15
|
+
static get is() { return "phone-form"; }
|
16
|
+
static get originalStyleUrls() {
|
17
|
+
return {
|
18
|
+
"$": ["../../giftback-form.css"]
|
19
|
+
};
|
20
|
+
}
|
21
|
+
static get styleUrls() {
|
22
|
+
return {
|
23
|
+
"$": ["../../giftback-form.css"]
|
24
|
+
};
|
25
|
+
}
|
26
|
+
static get properties() {
|
27
|
+
return {
|
28
|
+
"value": {
|
29
|
+
"type": "string",
|
30
|
+
"mutable": false,
|
31
|
+
"complexType": {
|
32
|
+
"original": "string",
|
33
|
+
"resolved": "string",
|
34
|
+
"references": {}
|
35
|
+
},
|
36
|
+
"required": false,
|
37
|
+
"optional": false,
|
38
|
+
"docs": {
|
39
|
+
"tags": [],
|
40
|
+
"text": ""
|
41
|
+
},
|
42
|
+
"attribute": "value",
|
43
|
+
"reflect": false
|
44
|
+
},
|
45
|
+
"loading": {
|
46
|
+
"type": "boolean",
|
47
|
+
"mutable": false,
|
48
|
+
"complexType": {
|
49
|
+
"original": "boolean",
|
50
|
+
"resolved": "boolean",
|
51
|
+
"references": {}
|
52
|
+
},
|
53
|
+
"required": false,
|
54
|
+
"optional": false,
|
55
|
+
"docs": {
|
56
|
+
"tags": [],
|
57
|
+
"text": ""
|
58
|
+
},
|
59
|
+
"attribute": "loading",
|
60
|
+
"reflect": false
|
61
|
+
},
|
62
|
+
"handlerSubmit": {
|
63
|
+
"type": "unknown",
|
64
|
+
"mutable": false,
|
65
|
+
"complexType": {
|
66
|
+
"original": "(phone: string) => void",
|
67
|
+
"resolved": "(phone: string) => void",
|
68
|
+
"references": {}
|
69
|
+
},
|
70
|
+
"required": false,
|
71
|
+
"optional": false,
|
72
|
+
"docs": {
|
73
|
+
"tags": [],
|
74
|
+
"text": ""
|
75
|
+
}
|
76
|
+
}
|
77
|
+
};
|
78
|
+
}
|
79
|
+
}
|
80
|
+
//# sourceMappingURL=phone-form.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"phone-form.js","sourceRoot":"","sources":["../../../../../../src/components/giftback-form/subcomponents/phone-form/phone-form.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC,EAAE,MAAM,eAAe,CAAC;AAMzD,MAAM,OAAO,SAAS;;;;;;IASlB,KAAK,CAAC,WAAW;QAEb,MAAM,KAAK,GAAG,MAAM,IAAI,CAAC,cAAc,CAAC,QAAQ,EAAE,CAAA;QAElD,MAAM,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;IACpC,CAAC;IAGD,MAAM;QACF,OAAO,CACH,EAAC,IAAI,qDAAC,KAAK,EAAC,gBAAgB;YACxB,8DAAO,KAAK,EAAC,cAAc,2FAAoF;YAC/G,yEAAkB,YAAY,EAAE,IAAI,CAAC,KAAK,EAAE,GAAG,EAAE,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,cAAc,GAAG,GAAG,GAAI;YAErF,mEAAY,MAAM,EAAC,cAAS,EAAC,OAAO,EAAE,IAAI,CAAC,OAAO,EAAE,OAAO,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,WAAW,EAAE,GAAK,CACvF,CACV,CAAA;IACL,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CACJ","sourcesContent":["import { Component, Host, Prop, h } from \"@stencil/core\";\n\n@Component({\n tag: 'phone-form',\n styleUrl: '../../giftback-form.css'\n})\nexport class PhoneForm {\n\n private phoneInputMask: HTMLPhoneInputMaskElement;\n\n @Prop() value: string;\n @Prop() loading: boolean;\n @Prop() handlerSubmit: (phone: string) => void;\n\n\n async handlePhone() {\n\n const phone = await this.phoneInputMask.getPhone()\n\n await this.handlerSubmit(phone);\n }\n\n\n render() {\n return (\n <Host class=\"crm-phone-form\">\n <label class=\"crm-subtitle\" >Digite o seu celular para verificar se há desconto disponível nessa compra</label>\n <phone-input-mask initialValue={this.value} ref={ref => this.phoneInputMask = ref} />\n\n <crm-button txtBtn=\"Avançar\" loading={this.loading} onClick={() => this.handlePhone() } />\n </Host>\n )\n }\n}"]}
|