@legalplace/wizardx-core 2.6.3 → 2.7.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.
Files changed (357) hide show
  1. package/CHANGELOG.md +43 -0
  2. package/dist/App.js +13 -4
  3. package/dist/PluginLoader.d.ts +3 -1
  4. package/dist/PluginLoader.js +12 -0
  5. package/dist/ThemeLoader.d.ts +2 -2
  6. package/dist/componentsConnectors/connectBox.d.ts +3 -1
  7. package/dist/componentsConnectors/connectDocument.d.ts +3 -1
  8. package/dist/componentsConnectors/connectHeader.d.ts +3 -1
  9. package/dist/componentsConnectors/connectMetaTitle.d.ts +3 -1
  10. package/dist/componentsConnectors/connectOption.d.ts +6 -2
  11. package/dist/componentsConnectors/connectOption.js +1 -1
  12. package/dist/componentsConnectors/connectPagination.d.ts +3 -1
  13. package/dist/componentsConnectors/connectPreview.d.ts +3 -1
  14. package/dist/componentsConnectors/connectProgress.d.ts +3 -1
  15. package/dist/componentsConnectors/connectRootOption.d.ts +3 -1
  16. package/dist/componentsConnectors/connectSection.d.ts +3 -1
  17. package/dist/componentsConnectors/connectSection.js +7 -10
  18. package/dist/componentsConnectors/connectSummary.d.ts +3 -1
  19. package/dist/componentsConnectors/connectSummaryItem.d.ts +3 -1
  20. package/dist/componentsConnectors/connectVariable.d.ts +6 -2
  21. package/dist/componentsConnectors/connectVariable.js +1 -1
  22. package/dist/componentsConnectors/connectWizardWrapper.d.ts +3 -1
  23. package/dist/componentsConnectors/connector/componentConnector.d.ts +5 -1
  24. package/dist/componentsConnectors/connector/componentConnector.js +44 -4
  25. package/dist/componentsConnectors/connector/index.d.ts +1 -0
  26. package/dist/componentsConnectors/connector/index.js +1 -0
  27. package/dist/componentsConnectors/index.d.ts +17 -0
  28. package/dist/componentsConnectors/index.js +17 -0
  29. package/dist/componentsConnectors/library.d.ts +43 -15
  30. package/dist/constants/phoneValidation.d.ts +0 -1
  31. package/dist/constants/phoneValidation.js +0 -1
  32. package/dist/helpers/apiEndpoint.d.ts +1 -0
  33. package/dist/helpers/apiEndpoint.js +4 -0
  34. package/dist/helpers/index.d.ts +4 -0
  35. package/dist/helpers/index.js +4 -0
  36. package/dist/helpers/propsEqualityCheck.d.ts +1 -0
  37. package/dist/helpers/propsEqualityCheck.js +9 -0
  38. package/dist/hooks/index.d.ts +4 -0
  39. package/dist/hooks/index.js +4 -0
  40. package/dist/hooks/useActions.d.ts +2 -0
  41. package/dist/hooks/useActions.js +4 -0
  42. package/dist/hooks/useDispatch.d.ts +1 -0
  43. package/dist/hooks/useDispatch.js +4 -0
  44. package/dist/hooks/useSelectors.d.ts +2 -0
  45. package/dist/hooks/useSelectors.js +4 -0
  46. package/dist/index.d.ts +13 -0
  47. package/dist/index.js +13 -0
  48. package/dist/libs/EventsTracking.d.ts +0 -1
  49. package/dist/libs/EventsTracking.js +0 -18
  50. package/dist/libs/PathReader.d.ts +10 -6
  51. package/dist/libs/PathReader.js +47 -28
  52. package/dist/libs/index.d.ts +5 -0
  53. package/dist/libs/index.js +5 -0
  54. package/dist/redux/actions/index.d.ts +9 -0
  55. package/dist/redux/actions/index.js +9 -0
  56. package/dist/redux/actions/library.d.ts +59 -63
  57. package/dist/redux/actions/sagas/index.d.ts +3 -0
  58. package/dist/redux/actions/sagas/index.js +3 -0
  59. package/dist/redux/actions/sagas/model.d.ts +1 -5
  60. package/dist/redux/constants/app.d.ts +2 -0
  61. package/dist/redux/constants/app.js +2 -0
  62. package/dist/redux/constants/index.d.ts +8 -0
  63. package/dist/redux/constants/index.js +8 -0
  64. package/dist/redux/constants/sagas/index.d.ts +3 -0
  65. package/dist/redux/constants/sagas/index.js +3 -0
  66. package/dist/redux/index.d.ts +5 -0
  67. package/dist/redux/index.js +5 -0
  68. package/dist/redux/middlewares/conditionsWatcherMiddleware.js +11 -5
  69. package/dist/redux/middlewares/conditionsWatcherMiddleware.test.js +120 -113
  70. package/dist/redux/middlewares/paginationWatcherMiddleware.js +2 -2
  71. package/dist/redux/middlewares/smartscriptMiddleware.js +8 -0
  72. package/dist/redux/reducers/pluginsStore.d.ts +3 -0
  73. package/dist/redux/reducers/pluginsStore.js +12 -0
  74. package/dist/redux/routerHistory.js +2 -2
  75. package/dist/redux/sagas/fetchModel.js +22 -6
  76. package/dist/redux/sagas/initInputs.js +6 -7
  77. package/dist/redux/sagas/saveData.js +3 -46
  78. package/dist/redux/sagas/setUserEmail.js +1 -28
  79. package/dist/redux/selectors/app.js +13 -18
  80. package/dist/redux/selectors/cache.d.ts +17 -0
  81. package/dist/redux/selectors/cache.js +35 -0
  82. package/dist/redux/selectors/conditions.js +7 -7
  83. package/dist/redux/selectors/index.d.ts +8 -0
  84. package/dist/redux/selectors/index.js +8 -0
  85. package/dist/redux/selectors/inputs.js +3 -3
  86. package/dist/redux/selectors/library.d.ts +2 -2
  87. package/dist/redux/selectors/references.js +26 -26
  88. package/dist/redux/selectors/selectors.d.ts +2 -2
  89. package/dist/redux/selectors/selectors.js +19 -8
  90. package/dist/redux/selectors/selectors.test.js +6 -6
  91. package/dist/redux/selectors/user.js +5 -5
  92. package/dist/redux/store.d.ts +1 -1
  93. package/dist/redux/store.js +12 -4
  94. package/dist/service/api.manager.d.ts +1 -6
  95. package/dist/service/index.d.ts +3 -0
  96. package/dist/service/index.js +3 -0
  97. package/dist/types/PluginConfig.type.d.ts +57 -0
  98. package/dist/types/PluginConfig.type.js +1 -0
  99. package/dist/types/State.type.d.ts +6 -0
  100. package/dist/types/config.type.d.ts +3 -1
  101. package/dist/types/index.d.ts +11 -0
  102. package/dist/types/index.js +11 -0
  103. package/package.json +11 -12
  104. package/.depcheckrc +0 -1
  105. package/.eslintignore +0 -2
  106. package/.eslintrc +0 -5
  107. package/__mocks__/fileMock.js +0 -1
  108. package/babel.config.json +0 -3
  109. package/dist/helpers/sendinblueHelper.d.ts +0 -4
  110. package/dist/helpers/sendinblueHelper.js +0 -46
  111. package/dist/libs/Extracts.d.ts +0 -20
  112. package/dist/libs/Extracts.js +0 -110
  113. package/jest.config.ts +0 -193
  114. package/setupJest.ts +0 -8
  115. package/src/App.test.tsx +0 -41
  116. package/src/App.tsx +0 -152
  117. package/src/Globals.ts +0 -69
  118. package/src/Loader.tsx +0 -8
  119. package/src/PluginLoader.test.tsx +0 -70
  120. package/src/PluginLoader.tsx +0 -407
  121. package/src/Shimmer.tsx +0 -108
  122. package/src/ThemeLoader.test.tsx +0 -82
  123. package/src/ThemeLoader.tsx +0 -95
  124. package/src/components/PluginRoute.tsx +0 -48
  125. package/src/components/SmartScript.tsx +0 -166
  126. package/src/components/UserLocked/UserLockedComponent.tsx +0 -33
  127. package/src/components/View.test.tsx +0 -110
  128. package/src/components/View.tsx +0 -114
  129. package/src/componentsConnectors/connectBox.test.tsx +0 -226
  130. package/src/componentsConnectors/connectBox.tsx +0 -70
  131. package/src/componentsConnectors/connectDocument.test.tsx +0 -108
  132. package/src/componentsConnectors/connectDocument.tsx +0 -64
  133. package/src/componentsConnectors/connectHeader.tsx +0 -21
  134. package/src/componentsConnectors/connectMetaTitle.test.tsx +0 -40
  135. package/src/componentsConnectors/connectMetaTitle.tsx +0 -8
  136. package/src/componentsConnectors/connectOption.tsx +0 -222
  137. package/src/componentsConnectors/connectPagination.tsx +0 -102
  138. package/src/componentsConnectors/connectPreview.tsx +0 -5
  139. package/src/componentsConnectors/connectProgress.tsx +0 -59
  140. package/src/componentsConnectors/connectRootOption.tsx +0 -95
  141. package/src/componentsConnectors/connectSection.tsx +0 -79
  142. package/src/componentsConnectors/connectSummary.tsx +0 -21
  143. package/src/componentsConnectors/connectSummaryItem.tsx +0 -102
  144. package/src/componentsConnectors/connectTermsheet.tsx +0 -359
  145. package/src/componentsConnectors/connectVariable.tsx +0 -191
  146. package/src/componentsConnectors/connectWizardWrapper.tsx +0 -30
  147. package/src/componentsConnectors/connector/componentConnector.tsx +0 -219
  148. package/src/componentsConnectors/library.ts +0 -35
  149. package/src/config.test.ts +0 -63
  150. package/src/config.ts +0 -11
  151. package/src/constants/emailValidation.ts +0 -2
  152. package/src/constants/phoneValidation.ts +0 -6
  153. package/src/definitions/path.join.d.ts +0 -4
  154. package/src/helpers/outputsParsing.ts +0 -412
  155. package/src/helpers/preloadTheme.ts +0 -17
  156. package/src/helpers/scriptsLoader.ts +0 -20
  157. package/src/helpers/sendinblueHelper.ts +0 -65
  158. package/src/hooks/usePrevious.ts +0 -9
  159. package/src/libs/ConditionsInitiator.ts +0 -164
  160. package/src/libs/ConditionsRunner/DataPopulator.ts +0 -266
  161. package/src/libs/ConditionsRunner.ts +0 -454
  162. package/src/libs/DocumentsOutputs.ts +0 -171
  163. package/src/libs/Eval/EvalBase.ts +0 -116
  164. package/src/libs/Eval/EvalFunctions.ts +0 -724
  165. package/src/libs/Eval/NumbersToLetters.ts +0 -185
  166. package/src/libs/EvalVariable.ts +0 -265
  167. package/src/libs/EventsTracking.ts +0 -276
  168. package/src/libs/Extracts.ts +0 -159
  169. package/src/libs/InputsInitiator.ts +0 -136
  170. package/src/libs/NumAuto.test.ts +0 -55
  171. package/src/libs/NumAuto.ts +0 -56
  172. package/src/libs/OvcConverter.ts +0 -285
  173. package/src/libs/PathReader.ts +0 -272
  174. package/src/libs/SectionValidity.test.ts +0 -146
  175. package/src/libs/SectionValidity.ts +0 -110
  176. package/src/libs/SmartScriptStore.ts +0 -492
  177. package/src/misc/test_model.ts +0 -14603
  178. package/src/misc/test_models/connectDocumen.testmodel.json +0 -178
  179. package/src/misc/test_models/setDefaults.testmodel.json +0 -279
  180. package/src/misc/test_models/testmodel.json +0 -1
  181. package/src/polyfills/index.ts +0 -5
  182. package/src/polyfills/objectValues.ts +0 -4
  183. package/src/polyfills/prepend.ts +0 -31
  184. package/src/polyfills/stringRepeat.ts +0 -44
  185. package/src/redux/actions/app.test.ts +0 -123
  186. package/src/redux/actions/app.ts +0 -249
  187. package/src/redux/actions/conditions.test.ts +0 -84
  188. package/src/redux/actions/conditions.ts +0 -135
  189. package/src/redux/actions/inputs.test.ts +0 -85
  190. package/src/redux/actions/inputs.ts +0 -111
  191. package/src/redux/actions/library.ts +0 -23
  192. package/src/redux/actions/mandatories.ts +0 -98
  193. package/src/redux/actions/references.test.ts +0 -48
  194. package/src/redux/actions/references.ts +0 -37
  195. package/src/redux/actions/sagas/data.test.ts +0 -11
  196. package/src/redux/actions/sagas/data.ts +0 -18
  197. package/src/redux/actions/sagas/model.test.ts +0 -14
  198. package/src/redux/actions/sagas/model.ts +0 -48
  199. package/src/redux/actions/sagas/user.ts +0 -25
  200. package/src/redux/actions/smartscript.ts +0 -55
  201. package/src/redux/actions/user.test.ts +0 -18
  202. package/src/redux/actions/user.ts +0 -41
  203. package/src/redux/constants/app.ts +0 -36
  204. package/src/redux/constants/conditions.ts +0 -25
  205. package/src/redux/constants/inputs.ts +0 -15
  206. package/src/redux/constants/mandatories.ts +0 -11
  207. package/src/redux/constants/references.ts +0 -7
  208. package/src/redux/constants/sagas/data.ts +0 -1
  209. package/src/redux/constants/sagas/model.ts +0 -2
  210. package/src/redux/constants/sagas/user.ts +0 -2
  211. package/src/redux/constants/smartscript.ts +0 -9
  212. package/src/redux/constants/user.ts +0 -6
  213. package/src/redux/listeners/subscriber.test.ts +0 -45
  214. package/src/redux/listeners/subscriber.ts +0 -29
  215. package/src/redux/middlewares/conditionsWatcherMiddleware.test.ts +0 -370
  216. package/src/redux/middlewares/conditionsWatcherMiddleware.ts +0 -321
  217. package/src/redux/middlewares/evaluationsWatcherMiddleware.test.ts +0 -323
  218. package/src/redux/middlewares/evaluationsWatcherMiddleware.ts +0 -250
  219. package/src/redux/middlewares/mandatoriesWatcherMiddleware.ts +0 -473
  220. package/src/redux/middlewares/multiplesActionsMiddleware.test.ts +0 -230
  221. package/src/redux/middlewares/multiplesActionsMiddleware.ts +0 -121
  222. package/src/redux/middlewares/paginationWatcherMiddleware.ts +0 -251
  223. package/src/redux/middlewares/pluginsHookMiddleware.ts +0 -24
  224. package/src/redux/middlewares/prefillerWatcherMiddleware.test.ts +0 -118
  225. package/src/redux/middlewares/prefillerWatcherMiddleware.ts +0 -462
  226. package/src/redux/middlewares/smartscriptMiddleware.ts +0 -228
  227. package/src/redux/middlewares/thirdpartyScriptsMiddleware.ts +0 -41
  228. package/src/redux/reducers/app/customizations/initCustomizationAutoDefault.ts +0 -16
  229. package/src/redux/reducers/app/customizations/initCustomizationMeta.ts +0 -16
  230. package/src/redux/reducers/app/instance/initInstance.ts +0 -29
  231. package/src/redux/reducers/app/instance/setDataStatus.ts +0 -16
  232. package/src/redux/reducers/app/instance/updateInstance.ts +0 -30
  233. package/src/redux/reducers/app/instance/updateInstancePaid.ts +0 -20
  234. package/src/redux/reducers/app/instance.test.ts +0 -106
  235. package/src/redux/reducers/app/meta/fetchModelFailed.ts +0 -11
  236. package/src/redux/reducers/app/meta/fetchModelNonBlocking.ts +0 -11
  237. package/src/redux/reducers/app/meta/fetchModelSucceeded.ts +0 -11
  238. package/src/redux/reducers/app/meta/fetchModelUnhealthy.ts +0 -18
  239. package/src/redux/reducers/app/meta/fetchModelUserLocked.ts +0 -11
  240. package/src/redux/reducers/app/meta/initMeta.ts +0 -22
  241. package/src/redux/reducers/app/meta/setModelUuid.ts +0 -17
  242. package/src/redux/reducers/app/meta.test.ts +0 -90
  243. package/src/redux/reducers/app/pagination/goNextPage.ts +0 -69
  244. package/src/redux/reducers/app/pagination/goPage.ts +0 -81
  245. package/src/redux/reducers/app/pagination/goPreviousPage.ts +0 -60
  246. package/src/redux/reducers/app/pagination/initPagination.ts +0 -46
  247. package/src/redux/reducers/app/pagination/updateAvailableAppStates.ts +0 -77
  248. package/src/redux/reducers/app/pagination.test.ts +0 -363
  249. package/src/redux/reducers/app/wizard/updateAvailableSections.ts +0 -40
  250. package/src/redux/reducers/app/wizard.test.ts +0 -84
  251. package/src/redux/reducers/app.test.ts +0 -336
  252. package/src/redux/reducers/app.ts +0 -150
  253. package/src/redux/reducers/conditions/addMultipleOccurency.test.ts +0 -131
  254. package/src/redux/reducers/conditions/addMultipleOccurency.ts +0 -155
  255. package/src/redux/reducers/conditions/deleteMultipleOccurency.test.ts +0 -95
  256. package/src/redux/reducers/conditions/deleteMultipleOccurency.ts +0 -141
  257. package/src/redux/reducers/conditions/initConditions.ts +0 -18
  258. package/src/redux/reducers/conditions/updateDocumentConditions.test.ts +0 -47
  259. package/src/redux/reducers/conditions/updateDocumentConditions.ts +0 -21
  260. package/src/redux/reducers/conditions/updateOptionConditions.ts +0 -24
  261. package/src/redux/reducers/conditions/updateOptionValidatorCondition.test.ts +0 -50
  262. package/src/redux/reducers/conditions/updateOptionValidatorCondition.ts +0 -28
  263. package/src/redux/reducers/conditions/updatePrefillerConditions.ts +0 -29
  264. package/src/redux/reducers/conditions/updateSectionConditions.ts +0 -28
  265. package/src/redux/reducers/conditions/updateVariableConditions.ts +0 -25
  266. package/src/redux/reducers/conditions/updateVariableValidatorCondition.test.ts +0 -50
  267. package/src/redux/reducers/conditions/updateVariableValidatorCondition.ts +0 -28
  268. package/src/redux/reducers/conditions.test.ts +0 -241
  269. package/src/redux/reducers/conditions.ts +0 -68
  270. package/src/redux/reducers/inputs/addMultipleOccurency.test.ts +0 -117
  271. package/src/redux/reducers/inputs/addMultipleOccurency.ts +0 -50
  272. package/src/redux/reducers/inputs/deleteMultipleOccurency.test.ts +0 -70
  273. package/src/redux/reducers/inputs/deleteMultipleOccurency.ts +0 -50
  274. package/src/redux/reducers/inputs/initOption.ts +0 -16
  275. package/src/redux/reducers/inputs/initVariable.ts +0 -16
  276. package/src/redux/reducers/inputs/updateOptionInput.ts +0 -24
  277. package/src/redux/reducers/inputs/updateVariableInput.ts +0 -24
  278. package/src/redux/reducers/inputs.test.ts +0 -221
  279. package/src/redux/reducers/inputs.ts +0 -51
  280. package/src/redux/reducers/mandatories/addMultipleOccurency.ts +0 -52
  281. package/src/redux/reducers/mandatories/deleteMultipleOccurency.ts +0 -55
  282. package/src/redux/reducers/mandatories/initMandatoryOption.ts +0 -17
  283. package/src/redux/reducers/mandatories/initMandatoryVariable.ts +0 -17
  284. package/src/redux/reducers/mandatories/setMandatoryIgnore.ts +0 -17
  285. package/src/redux/reducers/mandatories/setMandatoryOption.ts +0 -25
  286. package/src/redux/reducers/mandatories/setMandatorySection.ts +0 -20
  287. package/src/redux/reducers/mandatories/setMandatoryVariable.ts +0 -24
  288. package/src/redux/reducers/mandatories.ts +0 -56
  289. package/src/redux/reducers/references/initReferences.ts +0 -37
  290. package/src/redux/reducers/references/updateOptionMeta.ts +0 -73
  291. package/src/redux/reducers/references/updateVariableMeta.ts +0 -72
  292. package/src/redux/reducers/references.ts +0 -59
  293. package/src/redux/reducers/smartscript/enableSmartScript.ts +0 -13
  294. package/src/redux/reducers/smartscript/initSmartScriptTriggers.ts +0 -14
  295. package/src/redux/reducers/smartscript/updateSmartscriptOptionHidden.ts +0 -30
  296. package/src/redux/reducers/smartscript/updateSmartscriptVariableHidden.ts +0 -30
  297. package/src/redux/reducers/smartscript.ts +0 -47
  298. package/src/redux/reducers/user/initUser.ts +0 -15
  299. package/src/redux/reducers/user/setUserStatus.ts +0 -13
  300. package/src/redux/reducers/user/setUserValidToken.ts +0 -13
  301. package/src/redux/reducers/user.test.ts +0 -51
  302. package/src/redux/reducers/user.ts +0 -40
  303. package/src/redux/routerHistore.test.ts +0 -19
  304. package/src/redux/routerHistory.ts +0 -26
  305. package/src/redux/sagas/fetchModel.test.ts +0 -76
  306. package/src/redux/sagas/fetchModel.ts +0 -683
  307. package/src/redux/sagas/homogeneousRadioInputsSaga.ts +0 -42
  308. package/src/redux/sagas/initInputs.ts +0 -110
  309. package/src/redux/sagas/runner.test.ts +0 -12
  310. package/src/redux/sagas/runner.ts +0 -26
  311. package/src/redux/sagas/saveData.test.ts +0 -125
  312. package/src/redux/sagas/saveData.ts +0 -116
  313. package/src/redux/sagas/setDefaults.test.ts +0 -100
  314. package/src/redux/sagas/setDefaults.ts +0 -167
  315. package/src/redux/sagas/setUserEmail.ts +0 -221
  316. package/src/redux/selectors/app.test.ts +0 -162
  317. package/src/redux/selectors/app.ts +0 -331
  318. package/src/redux/selectors/conditions.test.ts +0 -92
  319. package/src/redux/selectors/conditions.ts +0 -293
  320. package/src/redux/selectors/inputs.test.ts +0 -72
  321. package/src/redux/selectors/inputs.ts +0 -76
  322. package/src/redux/selectors/library.ts +0 -17
  323. package/src/redux/selectors/mandatories.ts +0 -83
  324. package/src/redux/selectors/references.test.ts +0 -660
  325. package/src/redux/selectors/references.ts +0 -413
  326. package/src/redux/selectors/selectors.test.ts +0 -21
  327. package/src/redux/selectors/selectors.ts +0 -87
  328. package/src/redux/selectors/smartscript.ts +0 -30
  329. package/src/redux/selectors/user.test.ts +0 -39
  330. package/src/redux/selectors/user.ts +0 -45
  331. package/src/redux/store.test.ts +0 -22
  332. package/src/redux/store.ts +0 -100
  333. package/src/service/api.manager.ts +0 -261
  334. package/src/service/auth.service.ts +0 -5
  335. package/src/service/pardot.service.ts +0 -10
  336. package/src/tests-misc/plugins/jestTestPlugin/after.tsx +0 -5
  337. package/src/tests-misc/plugins/jestTestPlugin/before.tsx +0 -11
  338. package/src/tests-misc/plugins/jestTestPlugin/index.ts +0 -11
  339. package/src/tests-misc/plugins/jestTestPlugin/title.tsx +0 -8
  340. package/src/tests-misc/themes/jestTestTheme/components/EmailComponent.tsx +0 -5
  341. package/src/tests-misc/themes/jestTestTheme/components/TermsheetComponent.tsx +0 -5
  342. package/src/tests-misc/themes/jestTestTheme/components/WizardComponent.tsx +0 -5
  343. package/src/tests-misc/themes/jestTestTheme/faltyIndex.ts +0 -3
  344. package/src/tests-misc/themes/jestTestTheme/faltyIndexLoader.ts +0 -1
  345. package/src/tests-misc/themes/jestTestTheme/index.ts +0 -13
  346. package/src/types/Actions.type.ts +0 -612
  347. package/src/types/Components.type.ts +0 -181
  348. package/src/types/State.type.ts +0 -323
  349. package/src/types/Termsheet.type.ts +0 -28
  350. package/src/types/api.type.ts +0 -37
  351. package/src/types/config.type.ts +0 -55
  352. package/src/types/env.type.ts +0 -5
  353. package/src/types/getActions.type.ts +0 -3
  354. package/src/types/getConnectors.type.ts +0 -5
  355. package/src/types/getSelectors.type.ts +0 -3
  356. package/src/wizard-params.ts +0 -56
  357. package/tsconfig.json +0 -43
@@ -1,9 +1,10 @@
1
- import conditionsWatcherMiddleware from './conditionsWatcherMiddleware';
2
- import { addMultipleOccurencyAction, deleteMultipleOccurencyAction, updateOptionAction, updateVariableAction, } from '../actions/inputs';
3
- import { initConditionsAction } from '../actions/conditions';
1
+ import conditionsWatcherMiddleware from "./conditionsWatcherMiddleware";
2
+ import { addMultipleOccurencyAction, deleteMultipleOccurencyAction, updateOptionAction, updateVariableAction, } from "../actions/inputs";
3
+ import { initConditionsAction } from "../actions/conditions";
4
+ import { selectorsMiddleware } from "../selectors/selectors";
4
5
  const mockInputs = {
5
6
  variables: {
6
- 1: ['Hello'],
7
+ 1: ["Hello"],
7
8
  2: [],
8
9
  3: [],
9
10
  },
@@ -19,6 +20,11 @@ const mockInputs = {
19
20
  const mpi = {
20
21
  dispatch: jest.fn(),
21
22
  getState: () => ({
23
+ app: {
24
+ instance: {
25
+ dataStatus: "saved",
26
+ },
27
+ },
22
28
  inputs: mockInputs,
23
29
  }),
24
30
  };
@@ -53,21 +59,21 @@ const mockOptionsRelations = {
53
59
  dependants: [7, 8],
54
60
  },
55
61
  };
56
- jest.mock('../selectors/inputs', () => ({
62
+ jest.mock("../selectors/inputs", () => ({
57
63
  __esModule: true,
58
64
  selectOptionInput: (id) => mockInputs.options[id],
59
65
  selectOptionInputByIndex: (id, index) => mockInputs.options[id][index],
60
66
  selectVariableInput: (id) => mockInputs.variables[id],
61
67
  selectVariableInputByIndex: (id, index) => mockInputs.variables[id][index],
62
68
  }));
63
- jest.mock('../../libs/ConditionsRunner', () => {
69
+ jest.mock("../../libs/ConditionsRunner", () => {
64
70
  class ConditionsRunnerMock {
65
71
  constructor(dispatch) {
66
72
  this.dispatch = dispatch;
67
73
  }
68
74
  executeHooks(...args) {
69
75
  this.dispatch({
70
- type: 'EXEC_HOOKS_MOCK',
76
+ type: "EXEC_HOOKS_MOCK",
71
77
  arguments: args,
72
78
  });
73
79
  }
@@ -79,245 +85,246 @@ jest.mock('../../libs/ConditionsRunner', () => {
79
85
  });
80
86
  const mockOptionsConditions = {};
81
87
  const mockVariablesConditions = {};
82
- jest.mock('../selectors/references', () => ({
88
+ jest.mock("../selectors/references", () => ({
83
89
  __esModule: true,
84
90
  selectOptionRelations: (id) => mockOptionsRelations[id],
85
91
  selectOptionConditionsObject: (id) => mockOptionsConditions[id],
86
92
  selectVariableConditionsObject: (id) => mockVariablesConditions[id],
87
93
  }));
88
- describe('Conditions Watcher Middleware Test suit', () => {
94
+ describe("Conditions Watcher Middleware Test suit", () => {
89
95
  beforeEach(() => {
96
+ selectorsMiddleware(mpi)(next)({ type: "@INIT" });
90
97
  jest.clearAllMocks();
91
98
  });
92
- it('Completes INIT_CONDITIONS action correctly', () => {
99
+ it("Completes INIT_CONDITIONS action correctly", () => {
93
100
  conditionsWatcherMiddleware(mpi)(next)(initConditionsAction(initialConditions));
94
101
  expect(next.mock.calls.length).toBe(1);
95
- expect(next.mock.calls[0][0]).toStrictEqual(Object.assign({ type: 'INIT_CONDITIONS' }, initialConditions));
102
+ expect(next.mock.calls[0][0]).toStrictEqual(Object.assign({ type: "INIT_CONDITIONS" }, initialConditions));
96
103
  expect(mpi.dispatch.mock.calls.length).toBe(12);
97
104
  expect(mpi.dispatch.mock.calls[0][0]).toStrictEqual({
98
- type: 'EXEC_HOOKS_MOCK',
99
- arguments: ['options', 1, 0],
105
+ type: "EXEC_HOOKS_MOCK",
106
+ arguments: ["options", 1, 0],
100
107
  });
101
108
  expect(mpi.dispatch.mock.calls[1][0]).toStrictEqual({
102
- type: 'EXEC_HOOKS_MOCK',
103
- arguments: ['options', 2, 0],
109
+ type: "EXEC_HOOKS_MOCK",
110
+ arguments: ["options", 2, 0],
104
111
  });
105
112
  expect(mpi.dispatch.mock.calls[2][0]).toStrictEqual({
106
- type: 'EXEC_HOOKS_MOCK',
107
- arguments: ['options', 2, 1],
113
+ type: "EXEC_HOOKS_MOCK",
114
+ arguments: ["options", 2, 1],
108
115
  });
109
116
  expect(mpi.dispatch.mock.calls[3][0]).toStrictEqual({
110
- type: 'EXEC_HOOKS_MOCK',
111
- arguments: ['options', 3, 0],
117
+ type: "EXEC_HOOKS_MOCK",
118
+ arguments: ["options", 3, 0],
112
119
  });
113
120
  expect(mpi.dispatch.mock.calls[4][0]).toStrictEqual({
114
- type: 'EXEC_HOOKS_MOCK',
115
- arguments: ['options', 3, 1],
121
+ type: "EXEC_HOOKS_MOCK",
122
+ arguments: ["options", 3, 1],
116
123
  });
117
124
  expect(mpi.dispatch.mock.calls[5][0]).toStrictEqual({
118
- type: 'EXEC_HOOKS_MOCK',
119
- arguments: ['options', 4, 0],
125
+ type: "EXEC_HOOKS_MOCK",
126
+ arguments: ["options", 4, 0],
120
127
  });
121
128
  expect(mpi.dispatch.mock.calls[6][0]).toStrictEqual({
122
- type: 'EXEC_HOOKS_MOCK',
123
- arguments: ['options', 4, 1],
129
+ type: "EXEC_HOOKS_MOCK",
130
+ arguments: ["options", 4, 1],
124
131
  });
125
132
  expect(mpi.dispatch.mock.calls[7][0]).toStrictEqual({
126
- type: 'EXEC_HOOKS_MOCK',
127
- arguments: ['options', 7, 0],
133
+ type: "EXEC_HOOKS_MOCK",
134
+ arguments: ["options", 7, 0],
128
135
  });
129
136
  expect(mpi.dispatch.mock.calls[8][0]).toStrictEqual({
130
- type: 'EXEC_HOOKS_MOCK',
131
- arguments: ['options', 7, 1],
137
+ type: "EXEC_HOOKS_MOCK",
138
+ arguments: ["options", 7, 1],
132
139
  });
133
140
  expect(mpi.dispatch.mock.calls[9][0]).toStrictEqual({
134
- type: 'EXEC_HOOKS_MOCK',
135
- arguments: ['options', 8, 0],
141
+ type: "EXEC_HOOKS_MOCK",
142
+ arguments: ["options", 8, 0],
136
143
  });
137
144
  expect(mpi.dispatch.mock.calls[10][0]).toStrictEqual({
138
- type: 'EXEC_HOOKS_MOCK',
139
- arguments: ['options', 8, 1],
145
+ type: "EXEC_HOOKS_MOCK",
146
+ arguments: ["options", 8, 1],
140
147
  });
141
148
  expect(mpi.dispatch.mock.calls[11][0]).toStrictEqual({
142
- type: 'EXEC_HOOKS_MOCK',
143
- arguments: ['variables', 1, 0],
149
+ type: "EXEC_HOOKS_MOCK",
150
+ arguments: ["variables", 1, 0],
144
151
  });
145
152
  });
146
- it('Completes UPDATE_OPTION_INPUT action correctly', () => {
153
+ it("Completes UPDATE_OPTION_INPUT action correctly", () => {
147
154
  conditionsWatcherMiddleware(mpi)(next)(updateOptionAction(3, false, 0));
148
155
  expect(next.mock.calls.length).toBe(1);
149
156
  expect(next.mock.calls[0][0]).toStrictEqual({
150
- type: 'UPDATE_OPTION_INPUT',
157
+ type: "UPDATE_OPTION_INPUT",
151
158
  id: 3,
152
159
  index: 0,
153
160
  value: false,
154
161
  });
155
162
  expect(mpi.dispatch.mock.calls.length).toBe(2);
156
163
  expect(mpi.dispatch.mock.calls[0][0]).toStrictEqual({
157
- type: 'SET_DATA_STATUS',
158
- dataStatus: 'unsaved',
164
+ type: "SET_DATA_STATUS",
165
+ dataStatus: "unsaved",
159
166
  });
160
167
  expect(mpi.dispatch.mock.calls[1][0]).toStrictEqual({
161
- type: 'EXEC_HOOKS_MOCK',
162
- arguments: ['options', 3, 0],
168
+ type: "EXEC_HOOKS_MOCK",
169
+ arguments: ["options", 3, 0],
163
170
  });
164
171
  });
165
- it('Completes UPDATE_VARIABLE_INPUT action correctly', () => {
166
- conditionsWatcherMiddleware(mpi)(next)(updateVariableAction(1, 'Hey', 0));
172
+ it("Completes UPDATE_VARIABLE_INPUT action correctly", () => {
173
+ conditionsWatcherMiddleware(mpi)(next)(updateVariableAction(1, "Hey", 0));
167
174
  expect(next.mock.calls.length).toBe(1);
168
175
  expect(next.mock.calls[0][0]).toStrictEqual({
169
- type: 'UPDATE_VARIABLE_INPUT',
176
+ type: "UPDATE_VARIABLE_INPUT",
170
177
  id: 1,
171
178
  index: 0,
172
- value: 'Hey',
179
+ value: "Hey",
173
180
  });
174
181
  expect(mpi.dispatch.mock.calls.length).toBe(2);
175
182
  expect(mpi.dispatch.mock.calls[0][0]).toStrictEqual({
176
- type: 'SET_DATA_STATUS',
177
- dataStatus: 'unsaved',
183
+ type: "SET_DATA_STATUS",
184
+ dataStatus: "unsaved",
178
185
  });
179
186
  expect(mpi.dispatch.mock.calls[1][0]).toStrictEqual({
180
- type: 'EXEC_HOOKS_MOCK',
181
- arguments: ['variables', 1, 0],
187
+ type: "EXEC_HOOKS_MOCK",
188
+ arguments: ["variables", 1, 0],
182
189
  });
183
190
  });
184
- it('Completes ADD_MULTIPLE_OCCURENCY action correctly', () => {
191
+ it("Completes ADD_MULTIPLE_OCCURENCY action correctly", () => {
185
192
  conditionsWatcherMiddleware(mpi)(next)(addMultipleOccurencyAction(2));
186
193
  expect(next.mock.calls.length).toBe(1);
187
194
  expect(next.mock.calls[0][0]).toStrictEqual({
188
- type: 'ADD_MULTIPLE_OCCURENCY',
195
+ type: "ADD_MULTIPLE_OCCURENCY",
189
196
  id: 2,
190
197
  });
191
198
  expect(mpi.dispatch.mock.calls.length).toBe(15);
192
199
  expect(mpi.dispatch.mock.calls[0][0]).toStrictEqual({
193
- type: 'SET_DATA_STATUS',
194
- dataStatus: 'unsaved',
200
+ type: "SET_DATA_STATUS",
201
+ dataStatus: "unsaved",
195
202
  });
196
203
  expect(mpi.dispatch.mock.calls[1][0]).toStrictEqual({
197
- type: 'EXEC_HOOKS_MOCK',
198
- arguments: ['options', 2, 0],
204
+ type: "EXEC_HOOKS_MOCK",
205
+ arguments: ["options", 2, 0],
199
206
  });
200
207
  expect(mpi.dispatch.mock.calls[2][0]).toStrictEqual({
201
- type: 'EXEC_HOOKS_MOCK',
202
- arguments: ['options', 2, 1],
208
+ type: "EXEC_HOOKS_MOCK",
209
+ arguments: ["options", 2, 1],
203
210
  });
204
211
  expect(mpi.dispatch.mock.calls[3][0]).toStrictEqual({
205
- type: 'EXEC_HOOKS_MOCK',
206
- arguments: ['options', 3, 0],
212
+ type: "EXEC_HOOKS_MOCK",
213
+ arguments: ["options", 3, 0],
207
214
  });
208
215
  expect(mpi.dispatch.mock.calls[4][0]).toStrictEqual({
209
- type: 'EXEC_HOOKS_MOCK',
210
- arguments: ['options', 3, 1],
216
+ type: "EXEC_HOOKS_MOCK",
217
+ arguments: ["options", 3, 1],
211
218
  });
212
219
  expect(mpi.dispatch.mock.calls[5][0]).toStrictEqual({
213
- type: 'EXEC_HOOKS_MOCK',
214
- arguments: ['options', 4, 0],
220
+ type: "EXEC_HOOKS_MOCK",
221
+ arguments: ["options", 4, 0],
215
222
  });
216
223
  expect(mpi.dispatch.mock.calls[6][0]).toStrictEqual({
217
- type: 'EXEC_HOOKS_MOCK',
218
- arguments: ['options', 4, 1],
224
+ type: "EXEC_HOOKS_MOCK",
225
+ arguments: ["options", 4, 1],
219
226
  });
220
227
  expect(mpi.dispatch.mock.calls[7][0]).toStrictEqual({
221
- type: 'EXEC_HOOKS_MOCK',
222
- arguments: ['options', 7, 0],
228
+ type: "EXEC_HOOKS_MOCK",
229
+ arguments: ["options", 7, 0],
223
230
  });
224
231
  expect(mpi.dispatch.mock.calls[8][0]).toStrictEqual({
225
- type: 'EXEC_HOOKS_MOCK',
226
- arguments: ['options', 7, 1],
232
+ type: "EXEC_HOOKS_MOCK",
233
+ arguments: ["options", 7, 1],
227
234
  });
228
235
  expect(mpi.dispatch.mock.calls[9][0]).toStrictEqual({
229
- type: 'EXEC_HOOKS_MOCK',
230
- arguments: ['options', 8, 0],
236
+ type: "EXEC_HOOKS_MOCK",
237
+ arguments: ["options", 8, 0],
231
238
  });
232
239
  expect(mpi.dispatch.mock.calls[10][0]).toStrictEqual({
233
- type: 'EXEC_HOOKS_MOCK',
234
- arguments: ['options', 8, 1],
240
+ type: "EXEC_HOOKS_MOCK",
241
+ arguments: ["options", 8, 1],
235
242
  });
236
243
  expect(mpi.dispatch.mock.calls[11][0]).toStrictEqual({
237
- type: 'EXEC_HOOKS_MOCK',
238
- arguments: ['variables', 2, 0],
244
+ type: "EXEC_HOOKS_MOCK",
245
+ arguments: ["variables", 2, 0],
239
246
  });
240
247
  expect(mpi.dispatch.mock.calls[12][0]).toStrictEqual({
241
- type: 'EXEC_HOOKS_MOCK',
242
- arguments: ['variables', 2, 1],
248
+ type: "EXEC_HOOKS_MOCK",
249
+ arguments: ["variables", 2, 1],
243
250
  });
244
251
  expect(mpi.dispatch.mock.calls[13][0]).toStrictEqual({
245
- type: 'EXEC_HOOKS_MOCK',
246
- arguments: ['variables', 3, 0],
252
+ type: "EXEC_HOOKS_MOCK",
253
+ arguments: ["variables", 3, 0],
247
254
  });
248
255
  expect(mpi.dispatch.mock.calls[14][0]).toStrictEqual({
249
- type: 'EXEC_HOOKS_MOCK',
250
- arguments: ['variables', 3, 1],
256
+ type: "EXEC_HOOKS_MOCK",
257
+ arguments: ["variables", 3, 1],
251
258
  });
252
259
  });
253
- it('Completes DELETE_MULTIPLE_OCCURENCY action correctly', () => {
260
+ it("Completes DELETE_MULTIPLE_OCCURENCY action correctly", () => {
254
261
  conditionsWatcherMiddleware(mpi)(next)(deleteMultipleOccurencyAction(2, 1));
255
262
  expect(next.mock.calls.length).toBe(1);
256
263
  expect(next.mock.calls[0][0]).toStrictEqual({
257
- type: 'DELETE_MULTIPLE_OCCURENCY',
264
+ type: "DELETE_MULTIPLE_OCCURENCY",
258
265
  id: 2,
259
266
  index: 1,
260
267
  });
261
268
  expect(mpi.dispatch.mock.calls.length).toBe(15);
262
269
  expect(mpi.dispatch.mock.calls[0][0]).toStrictEqual({
263
- type: 'SET_DATA_STATUS',
264
- dataStatus: 'unsaved',
270
+ type: "SET_DATA_STATUS",
271
+ dataStatus: "unsaved",
265
272
  });
266
273
  expect(mpi.dispatch.mock.calls[1][0]).toStrictEqual({
267
- type: 'EXEC_HOOKS_MOCK',
268
- arguments: ['options', 2, 0],
274
+ type: "EXEC_HOOKS_MOCK",
275
+ arguments: ["options", 2, 0],
269
276
  });
270
277
  expect(mpi.dispatch.mock.calls[2][0]).toStrictEqual({
271
- type: 'EXEC_HOOKS_MOCK',
272
- arguments: ['options', 2, 1],
278
+ type: "EXEC_HOOKS_MOCK",
279
+ arguments: ["options", 2, 1],
273
280
  });
274
281
  expect(mpi.dispatch.mock.calls[3][0]).toStrictEqual({
275
- type: 'EXEC_HOOKS_MOCK',
276
- arguments: ['options', 3, 0],
282
+ type: "EXEC_HOOKS_MOCK",
283
+ arguments: ["options", 3, 0],
277
284
  });
278
285
  expect(mpi.dispatch.mock.calls[4][0]).toStrictEqual({
279
- type: 'EXEC_HOOKS_MOCK',
280
- arguments: ['options', 3, 1],
286
+ type: "EXEC_HOOKS_MOCK",
287
+ arguments: ["options", 3, 1],
281
288
  });
282
289
  expect(mpi.dispatch.mock.calls[5][0]).toStrictEqual({
283
- type: 'EXEC_HOOKS_MOCK',
284
- arguments: ['options', 4, 0],
290
+ type: "EXEC_HOOKS_MOCK",
291
+ arguments: ["options", 4, 0],
285
292
  });
286
293
  expect(mpi.dispatch.mock.calls[6][0]).toStrictEqual({
287
- type: 'EXEC_HOOKS_MOCK',
288
- arguments: ['options', 4, 1],
294
+ type: "EXEC_HOOKS_MOCK",
295
+ arguments: ["options", 4, 1],
289
296
  });
290
297
  expect(mpi.dispatch.mock.calls[7][0]).toStrictEqual({
291
- type: 'EXEC_HOOKS_MOCK',
292
- arguments: ['options', 7, 0],
298
+ type: "EXEC_HOOKS_MOCK",
299
+ arguments: ["options", 7, 0],
293
300
  });
294
301
  expect(mpi.dispatch.mock.calls[8][0]).toStrictEqual({
295
- type: 'EXEC_HOOKS_MOCK',
296
- arguments: ['options', 7, 1],
302
+ type: "EXEC_HOOKS_MOCK",
303
+ arguments: ["options", 7, 1],
297
304
  });
298
305
  expect(mpi.dispatch.mock.calls[9][0]).toStrictEqual({
299
- type: 'EXEC_HOOKS_MOCK',
300
- arguments: ['options', 8, 0],
306
+ type: "EXEC_HOOKS_MOCK",
307
+ arguments: ["options", 8, 0],
301
308
  });
302
309
  expect(mpi.dispatch.mock.calls[10][0]).toStrictEqual({
303
- type: 'EXEC_HOOKS_MOCK',
304
- arguments: ['options', 8, 1],
310
+ type: "EXEC_HOOKS_MOCK",
311
+ arguments: ["options", 8, 1],
305
312
  });
306
313
  expect(mpi.dispatch.mock.calls[11][0]).toStrictEqual({
307
- type: 'EXEC_HOOKS_MOCK',
308
- arguments: ['variables', 2, 0],
314
+ type: "EXEC_HOOKS_MOCK",
315
+ arguments: ["variables", 2, 0],
309
316
  });
310
317
  expect(mpi.dispatch.mock.calls[12][0]).toStrictEqual({
311
- type: 'EXEC_HOOKS_MOCK',
312
- arguments: ['variables', 2, 1],
318
+ type: "EXEC_HOOKS_MOCK",
319
+ arguments: ["variables", 2, 1],
313
320
  });
314
321
  expect(mpi.dispatch.mock.calls[13][0]).toStrictEqual({
315
- type: 'EXEC_HOOKS_MOCK',
316
- arguments: ['variables', 3, 0],
322
+ type: "EXEC_HOOKS_MOCK",
323
+ arguments: ["variables", 3, 0],
317
324
  });
318
325
  expect(mpi.dispatch.mock.calls[14][0]).toStrictEqual({
319
- type: 'EXEC_HOOKS_MOCK',
320
- arguments: ['variables', 3, 1],
326
+ type: "EXEC_HOOKS_MOCK",
327
+ arguments: ["variables", 3, 1],
321
328
  });
322
329
  });
323
330
  });
@@ -21,8 +21,8 @@ const watchLocationChange = (mpi, next, action) => {
21
21
  const pathReader = new PathReader(mpi.getState());
22
22
  if (selectPermalink() === "") {
23
23
  mpi.dispatch(initMetaAction({
24
- permalink: pathReader.currentPermalink,
25
- prefix: pathReader.prefix,
24
+ permalink: pathReader.currentPermalink || "",
25
+ prefix: pathReader.currentPrefix || "",
26
26
  id: 0,
27
27
  title: "",
28
28
  modelVersion: 0,
@@ -9,6 +9,14 @@ import { updateOptionAction, updateVariableAction } from "../actions/inputs";
9
9
  let iframe = null;
10
10
  const watchEnableSmartScript = (mpi, next, action) => {
11
11
  next(action);
12
+ if (PathReader.isSmartScriptPath()) {
13
+ return;
14
+ }
15
+ const iframeElement = document.querySelector("#lp-smartscript");
16
+ if (iframeElement) {
17
+ iframe = iframeElement;
18
+ return;
19
+ }
12
20
  iframe = document.createElement("iframe");
13
21
  iframe.id = "lp-smartscript";
14
22
  iframe.setAttribute("style", "position: absolute; width:0; height:0; border:0;");
@@ -0,0 +1,3 @@
1
+ import { AnyAction } from "redux";
2
+ import { StateType } from "../../types/State.type";
3
+ export declare const pluginsStoreReducer: (state: StateType.PluginsStore | undefined, action: AnyAction) => StateType.PluginsStore;
@@ -0,0 +1,12 @@
1
+ import { getPluginsStoreReducers } from "../../PluginLoader";
2
+ export const pluginsStoreReducer = (state = {}, action) => {
3
+ const pluginsStoreReducers = getPluginsStoreReducers();
4
+ const plugins = Object.keys(pluginsStoreReducers);
5
+ const newState = Object.assign({}, state);
6
+ for (let i = 0; i < plugins.length; i += 1) {
7
+ const currentPlugin = plugins[i];
8
+ const reducer = pluginsStoreReducers[currentPlugin];
9
+ newState[currentPlugin] = reducer(newState[currentPlugin], action);
10
+ }
11
+ return newState;
12
+ };
@@ -4,8 +4,8 @@ export const createHistory = (historyType) => {
4
4
  history =
5
5
  historyType === "memory"
6
6
  ? createMemoryHistory({
7
- initialEntries: ["/one", "/two"],
8
- initialIndex: 1,
7
+ initialEntries: ["/"],
8
+ initialIndex: 0,
9
9
  })
10
10
  : createBrowserHistory();
11
11
  return history;
@@ -26,7 +26,7 @@ function* setFetchModelToNonBlocking(firstCurrentAppState) {
26
26
  currentPage: 1,
27
27
  greatestPage: 1,
28
28
  currentSectionId: 0,
29
- availableSections: [],
29
+ availableSections: [0],
30
30
  currentAppState: firstCurrentAppState || "wizard",
31
31
  availableAppStates: ["wizard"],
32
32
  }));
@@ -42,10 +42,12 @@ function* getClientConfig(permalink, uniqid) {
42
42
  throw new Error(`Unable to fetch client config, we did not receive any response`);
43
43
  }
44
44
  clientConfigResponse = yield call([clientConfigResponse, "json"]);
45
- if ((_a = clientConfigResponse.clientConfig.metadata) === null || _a === void 0 ? void 0 : _a.apiEndpoint) {
45
+ if (!getConfig().disableRemoteConfig &&
46
+ ((_a = clientConfigResponse.clientConfig.metadata) === null || _a === void 0 ? void 0 : _a.apiEndpoint)) {
46
47
  updateConfig(Object.assign(Object.assign({}, getConfig()), { apiEndpoint: (_b = clientConfigResponse.clientConfig.metadata) === null || _b === void 0 ? void 0 : _b.apiEndpoint }));
47
48
  }
48
- if ((_c = clientConfigResponse.clientConfig.metadata) === null || _c === void 0 ? void 0 : _c.plugins) {
49
+ if (!getConfig().disableRemoteConfig &&
50
+ ((_c = clientConfigResponse.clientConfig.metadata) === null || _c === void 0 ? void 0 : _c.plugins)) {
49
51
  yield call(loadPlugins, (_d = clientConfigResponse.clientConfig.metadata) === null || _d === void 0 ? void 0 : _d.plugins);
50
52
  }
51
53
  else
@@ -55,7 +57,8 @@ function* getClientConfig(permalink, uniqid) {
55
57
  if (/compactTheme/.test(window.location.href)) {
56
58
  yield call(setWizardTheme, { name: "compact" });
57
59
  }
58
- else if ((_g = (_f = clientConfigResponse.clientConfig.metadata) === null || _f === void 0 ? void 0 : _f.theme) === null || _g === void 0 ? void 0 : _g.name) {
60
+ else if (!getConfig().disableRemoteConfig &&
61
+ ((_g = (_f = clientConfigResponse.clientConfig.metadata) === null || _f === void 0 ? void 0 : _f.theme) === null || _g === void 0 ? void 0 : _g.name)) {
59
62
  yield call(setWizardTheme, clientConfigResponse.clientConfig.metadata.theme);
60
63
  }
61
64
  else {
@@ -87,7 +90,6 @@ function* getWizardConfig(permalink, uniqidParam, prefix, queryParams) {
87
90
  return { modelUuid: response.modelUuid };
88
91
  }
89
92
  function* fetchModelInformation(modelUuid, permalink, prefix, queryParams) {
90
- var _a;
91
93
  let response = yield call(fetch, ...getModelInformationArguments(modelUuid, queryParams));
92
94
  if (response === undefined) {
93
95
  throw new Error(`Unable to fetch wizard config, we did not receive any response`);
@@ -104,7 +106,14 @@ function* fetchModelInformation(modelUuid, permalink, prefix, queryParams) {
104
106
  const meta = Object.assign(Object.assign({}, response.meta), { permalink,
105
107
  prefix });
106
108
  yield put(initMetaAction(meta));
107
- document.title = `${meta.title} - ${((_a = getConfig().brand) === null || _a === void 0 ? void 0 : _a.name) || "LegalPlace"}`;
109
+ const { brand } = getConfig();
110
+ const { name, documentTitle } = brand || {};
111
+ if (documentTitle !== false) {
112
+ document.title =
113
+ typeof documentTitle === "string"
114
+ ? documentTitle
115
+ : `${meta.title} - ${name || "LegalPlace"}`;
116
+ }
108
117
  const { references, customization, smartScript } = response;
109
118
  yield put(initReferencesAction(references));
110
119
  if (customization.disableAutoDefault !== undefined)
@@ -230,6 +239,13 @@ function* fetchModelPrerequisites(action) {
230
239
  const queryParams = new URLSearchParams(window.location.search);
231
240
  if (pathReader.modelVersion)
232
241
  queryParams.set("version", pathReader.modelVersion);
242
+ const { apiQueryParams } = getConfig().metadata || {};
243
+ if (apiQueryParams) {
244
+ Object.keys(apiQueryParams).forEach((currentParam) => {
245
+ if (apiQueryParams[currentParam] !== undefined)
246
+ queryParams.set(currentParam, apiQueryParams[currentParam]);
247
+ });
248
+ }
233
249
  const clientConfigReturnValue = yield call(getClientConfig, permalink, uniqid || "");
234
250
  const wizardConfig = yield call(getWizardConfig, permalink, uniqidParam, prefix, queryParams);
235
251
  yield put(fetchModelAction(permalink, prefix, uniqid, uniqidParam, queryParams, pathReader, urlParams, clientConfigReturnValue, wizardConfig));
@@ -15,12 +15,10 @@ export function* initInputsDecorator(action) {
15
15
  yield put(initConditionsAction(conditions));
16
16
  const optionsIds = Object.keys(inputs.options);
17
17
  for (let i = 0; i < optionsIds.length; i += 1) {
18
- let optionId = parseInt(optionsIds[i], 10);
18
+ const optionId = parseInt(optionsIds[i], 10);
19
19
  let values = inputs.options[optionId];
20
20
  yield put(initOptionAction(optionId, values));
21
- const { meta: meta2 } = references.options[optionId];
22
- const { type } = meta2;
23
- let { mandatory } = meta2;
21
+ const { type, mandatory } = references.options[optionId].meta;
24
22
  let sendOptionAction = true;
25
23
  if (["checkbox", "radio"].includes(type)) {
26
24
  if (type === "radio") {
@@ -39,10 +37,11 @@ export function* initInputsDecorator(action) {
39
37
  }
40
38
  }
41
39
  }
42
- mandatory = references.options[parentId].meta.mandatory;
43
- optionId = parentId;
40
+ const { mandatory: parentMandatory } = references.options[parentId].meta;
41
+ if (parentMandatory && sendOptionAction)
42
+ yield put(initMandatoryOptionAction(parentId, values));
44
43
  }
45
- if (mandatory === true && sendOptionAction === true) {
44
+ else if (mandatory && sendOptionAction) {
46
45
  yield put(initMandatoryOptionAction(optionId, values));
47
46
  }
48
47
  }
@@ -1,64 +1,21 @@
1
- var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
2
- function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
3
- return new (P || (P = Promise))(function (resolve, reject) {
4
- function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
5
- function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
6
- function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
7
- step((generator = generator.apply(thisArg, _arguments || [])).next());
8
- });
9
- };
10
1
  import { call, put, takeLatest } from "redux-saga/effects";
11
- import { v4 as uuid } from "uuid";
12
2
  import { setDataStatus } from "../actions/app";
13
- import { selectPermalink, selectInstanceUniqid, selectDocumentTitle, selectInstanceIsPaid, } from "../selectors/app";
3
+ import { selectPermalink, selectInstanceUniqid } from "../selectors/app";
14
4
  import { SAVE_DATA } from "../constants/sagas/data";
15
5
  import { selectInputs } from "../selectors/inputs";
16
6
  import { OvcConverter } from "../../libs/OvcConverter";
17
7
  import { updateInstanceArguments } from "../../service/api.manager";
18
- import { getSendinblueIdentifyAttributes } from "../../helpers/sendinblueHelper";
19
- import { getConfig } from "../../config";
20
- import { selectUserEmail } from "../selectors/user";
21
- const getSendinblueData = (uniqid, paid) => __awaiter(void 0, void 0, void 0, function* () {
22
- const email = selectUserEmail();
23
- const apiEndpoint = getConfig().apiEndpoint + (/\/$/.test(getConfig().apiEndpoint) ? "" : "/");
24
- const ovc = OvcConverter.convertToOvc(selectInputs());
25
- const nbFilledVars = Object.keys(ovc.v).reduce((p, c) => {
26
- const currentValue = ovc.v[c];
27
- const o = Array.isArray(currentValue)
28
- ? currentValue.reduce((_p, _c) => _p + (_c !== "" ? 1 : 0), 0)
29
- : currentValue !== ""
30
- ? 1
31
- : 0;
32
- return p + o;
33
- }, 0);
34
- const attributes = yield getSendinblueIdentifyAttributes(uniqid, selectDocumentTitle(), nbFilledVars, paid, window.location.host);
35
- return [apiEndpoint, email, attributes];
36
- });
37
8
  function* saveDataDecorator(action) {
38
9
  try {
39
10
  yield put(setDataStatus("saving"));
40
11
  const permalink = selectPermalink();
41
12
  const uniqid = selectInstanceUniqid();
13
+ if (uniqid === undefined)
14
+ throw new Error(`Cannot save data, uniqid is not defined`);
42
15
  const response = yield call(fetch, ...updateInstanceArguments(permalink, uniqid, OvcConverter.convertToOvc(selectInputs()), action.confirmAnswer ? 0 : 1, action.additionalProperties));
43
16
  const responseData = yield call([response, "json"]);
44
17
  if (action.redirect === true) {
45
18
  if (responseData.redirect_to) {
46
- try {
47
- const [apiEndpoint, email, attributes] = yield call(getSendinblueData, [uniqid, selectInstanceIsPaid()]);
48
- yield call(fetch, `${apiEndpoint}event/create/${uniqid}/${uuid()}`, {
49
- method: "POST",
50
- credentials: "include",
51
- headers: {
52
- "Content-Type": "application/json",
53
- },
54
- body: JSON.stringify({
55
- email,
56
- attributes,
57
- }),
58
- });
59
- }
60
- catch (error) {
61
- }
62
19
  window.onbeforeunload = () => { };
63
20
  window.location.href = responseData.redirect_to;
64
21
  }