project-booster-vue 9.44.12 → 9.45.0
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/package.json +1 -1
- package/src/components/trezor/PbTrezor.vue +22 -0
- package/src/components/trezor/PbTrezorInterface.ts +6 -0
- package/src/components/trezor/__snapshots__/storyshots-puppeteer-test-puppeteer-ts-image-storyshots-project-booster-components-trezor-pb-trezor-/360/237/246/240-101-sandbox-1-snap.png +0 -0
- package/src/components/trezor/default-payload.json +8 -0
package/package.json
CHANGED
|
@@ -116,6 +116,7 @@ import MLink from '../mozaic/link/MLink.vue';
|
|
|
116
116
|
import MTextInput from '../mozaic/text-input/MTextInput.vue';
|
|
117
117
|
import { ScenarioStepAnswer } from '@/types/pb/Scenario';
|
|
118
118
|
import { object, string, boolean, number } from 'yup';
|
|
119
|
+
import { TrezorInterface } from './PbTrezorInterface';
|
|
119
120
|
import objectPath from 'object-path';
|
|
120
121
|
const BACK_ICON =
|
|
121
122
|
'https://storage.googleapis.com/project-booster-media/mozaic-icons/svg/Navigation_Arrow_Arrow--Left_16px.svg';
|
|
@@ -187,6 +188,26 @@ export default defineComponent({
|
|
|
187
188
|
props.payload.viewModel.defaultValue?.zipcode?.path,
|
|
188
189
|
) || null;
|
|
189
190
|
|
|
191
|
+
const convertToTypeOf = (typedVar: string, input: any): string | number => {
|
|
192
|
+
switch (typedVar) {
|
|
193
|
+
case 'string':
|
|
194
|
+
return input.toString();
|
|
195
|
+
case 'float':
|
|
196
|
+
return parseFloat(input);
|
|
197
|
+
case 'integer':
|
|
198
|
+
return parseInt(input);
|
|
199
|
+
default:
|
|
200
|
+
return input;
|
|
201
|
+
}
|
|
202
|
+
};
|
|
203
|
+
|
|
204
|
+
const metadata = props.payload.viewModel.metadata;
|
|
205
|
+
let sendingMetadata: any;
|
|
206
|
+
|
|
207
|
+
metadata.forEach((meta: TrezorInterface) => {
|
|
208
|
+
sendingMetadata[meta.attribut] = convertToTypeOf(meta.type, getAnswerValue(meta.answerCode, meta.path)) || null;
|
|
209
|
+
});
|
|
210
|
+
|
|
190
211
|
let formData = ref<any>({
|
|
191
212
|
values: {
|
|
192
213
|
lastname: '',
|
|
@@ -239,6 +260,7 @@ export default defineComponent({
|
|
|
239
260
|
},
|
|
240
261
|
optin: formData.value.values.optin,
|
|
241
262
|
optinPartners: formData.value.values.optinPartners,
|
|
263
|
+
metadata: sendingMetadata,
|
|
242
264
|
},
|
|
243
265
|
typeLead: props.payload.viewModel.typeLead,
|
|
244
266
|
});
|
|
@@ -9,6 +9,14 @@
|
|
|
9
9
|
"path": "value"
|
|
10
10
|
}
|
|
11
11
|
},
|
|
12
|
+
"metadata": [
|
|
13
|
+
{
|
|
14
|
+
"attribut": "surface",
|
|
15
|
+
"type": "float",
|
|
16
|
+
"answerCode": "LMFR_HEAT_PUMP_AIR_WATER_QUESTION_SURFACE_AREA",
|
|
17
|
+
"path": "space"
|
|
18
|
+
}
|
|
19
|
+
],
|
|
12
20
|
"translationErrors": {
|
|
13
21
|
"lastname": "Le nom est requis",
|
|
14
22
|
"firstname": "Le prénom est requis",
|